Функции за променливи
PHP Manual

var_export

(PHP 4 >= 4.2.0, PHP 5)

var_exportИзвежда или връща удобно за анализ представяне на променлива във вид на низ

Описание

mixed var_export ( mixed $expression [, bool $return ] )

var_export() връща структурирана информация за дадена променлива. Тя е сходна с функцията var_dump(), с една разлика: връщаното представяне е валиден PHP код.

Параметри

expression

Променливата, която желаете да експортирате.

return

Ако параметърът се използва и стойността му е TRUE, функцията var_export() ще върне представянето на променливата вместо да изведе стойността й.

Забележка: Тази функция използва вътрешно буфериране на изхода с този параметър, така че не може да бъде използвана в обратно-извикващата се функция ob_start().

Връщани стойности

Връща представянето на променливата, когато параметърът return е установен в TRUE. В противен случай връща NULL.

Дневник на промените

Версия Описание
5.1.0 Възможност за експортиране на класове и масиви съдържащи класове посредством вълшебния метод __set_state.

Примери

Example #1 Примери за var_export()

<?php
$a 
= array (12, array ("a""b""c"));
var_export($a);
?>

Примерът по-горе ще изведе:

array (
  0 => 1,
  1 => 2,
  2 => 
  array (
    0 => 'a',
    1 => 'b',
    2 => 'c',
  ),
)
<?php

$b 
3.1;
$v var_export($btrue);
echo 
$v;

?>

Примерът по-горе ще изведе:

3.1

Example #2 Експортиране на класове, въведено от PHP 5.1.0

<?php
class { public $var; }
$a = new A;
$a->var 5;
var_export($a);
?>

Примерът по-горе ще изведе:

A::__set_state(array(
   'var' => 5,
))

Example #3 Употреба на __set_state (от PHP 5.1.0)

<?php
class A
{
    public 
$var1;
    public 
$var2;

    public static function 
__set_state($an_array)
    {
        
$obj = new A;
        
$obj->var1 $an_array['var1'];
        
$obj->var2 $an_array['var2'];
        return 
$obj;
    }
}

$a = new A;
$a->var1 5;
$a->var2 'foo';

eval(
'$b = ' var_export($atrue) . ';'); // $b = A::__set_state(array(
                                            //    'var1' => 5,
                                            //    'var2' => 'foo',
                                            // ));
var_dump($b);
?>

Примерът по-горе ще изведе:

object(A)#2 (2) {
  ["var1"]=>
  int(5)
  ["var2"]=>
  string(3) "foo"
}

Бележки

Забележка: Променливи от тип resource не могат да се експортират с тази функция.

Забележка: var_export() не поддържа циклични референции, тъй като ще бъде почти невъзможно да се генерира анализируем PHP код за това. Ако искате да направите нещо с пълното представяне на масив или обект, използвайте функцията serialize().

Вж. също


Функции за променливи
PHP Manual