PHPerKaigi 2025

var_representation

(PECL var_representation >= 0.1.0)

var_representationВозвращает короткое, читаемое, разборчивое строковое представление переменной

Описание

var_representation(mixed $value, int $flags = 0): string

var_representation() (модуль PECL var_representation) возвращает строку со структурированной информацией о данной переменной. Функция похожа на var_export() с различиями в отступах, экранировании строк и представлениях массива.

Список параметров

value

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

flags

Битовая маска, состоящая из: VAR_REPRESENTATION_SINGLE_LINE, VAR_REPRESENTATION_UNESCAPED. Поведение этих констант описано на странице константы var_representation.

Возвращаемые значения

Возвращает представление переменной.

Примеры

Пример #1 Пример использования var_representation()

<?php
$a
= [1, 2, ['key' => 'value']];
echo
var_representation($a), "\n";
echo
var_representation($a, VAR_REPRESENTATION_SINGLE_LINE), "\n";
?>

Результат выполнения приведённого примера:

[
  1,
  2,
  [
    'key' => 'value',
  ],
]
[1, 2, ['key' => 'value']]

Пример #2 Экранирование управляющих символов

<?php
echo var_representation("Content-Length: 123\r\n");

Результат выполнения приведённого примера:

"Content-Length: 123\r\n"

Пример #3 Экспорт stdClass

<?php
$person
= new stdClass;
$person->name = 'ElePHPant ElePHPantsdotter';
$person->website = 'https://php.net/elephpant.php';

echo
var_representation($person);

Результат выполнения приведённого примера:

(object) [
  'name' => 'ElePHPant ElePHPantsdotter',
  'website' => 'https://php.net/elephpant.php',
]

Пример #4 Экспортирование классов

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

Результат выполнения приведённого примера:

\A::__set_state([
  'var' => 5,
])

Пример #5 Пример использования __set_state()

<?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_representation($a) . ';'); // $b = \A::__set_state([
// 'var1' => 5,
// 'var2' => 'foo',
// ]);
var_dump($b);
?>

Результат выполнения приведённого примера:

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

Смотрите также

  • var_export() - Выводит или возвращает интерпретируемое строковое представление переменной

Добавить

Примечания пользователей

Пользователи ещё не добавляли примечания для страницы
To Top