我想将var_dump的输出捕获到一个字符串中。
PHP文档说;
与任何直接将结果输出到浏览器的操作一样,输出控制函数可用于捕获该函数的输出,并将其保存为字符串(例如)。
有什么例子可以说明它是如何工作的?
print_r()不是一个有效的可能性,因为它不会给我我需要的信息。
我想将var_dump的输出捕获到一个字符串中。
PHP文档说;
与任何直接将结果输出到浏览器的操作一样,输出控制函数可用于捕获该函数的输出,并将其保存为字符串(例如)。
有什么例子可以说明它是如何工作的?
print_r()不是一个有效的可能性,因为它不会给我我需要的信息。
尝试var_export
你可能想要检查var_export -虽然它不提供与var_dump相同的输出,但它提供了第二个$return参数,这将导致它返回输出而不是打印输出:
$debug = var_export($my_var, true);
Why?
与使用ob_start和ob_get_clean()相比,我更喜欢这个一行程序。我还发现输出更容易阅读,因为它只是PHP代码。
var_dump和var_export之间的区别在于var_export返回“变量的可解析字符串表示”,而var_dump只是转储关于变量的信息。在实践中,这意味着var_export为您提供了有效的PHP代码(但可能不会为您提供关于变量的足够多的信息,特别是在使用资源时)。
演示:
$demo = array(
"bool" => false,
"int" => 1,
"float" => 3.14,
"string" => "hello world",
"array" => array(),
"object" => new stdClass(),
"resource" => tmpfile(),
"null" => null,
);
// var_export -- nice, one-liner
$debug_export = var_export($demo, true);
// var_dump
ob_start();
var_dump($demo);
$debug_dump = ob_get_clean();
// print_r -- included for completeness, though not recommended
$debug_printr = print_r($demo, true);
输出的差异:
Var_export(上面例子中的$debug_export):
array (
'bool' => false,
'int' => 1,
'float' => 3.1400000000000001,
'string' => 'hello world',
'array' =>
array (
),
'object' =>
stdClass::__set_state(array(
)),
'resource' => NULL, // Note that this resource pointer is now NULL
'null' => NULL,
)
Var_dump(上面例子中的$debug_dump):
array(8) {
["bool"]=>
bool(false)
["int"]=>
int(1)
["float"]=>
float(3.14)
["string"]=>
string(11) "hello world"
["array"]=>
array(0) {
}
["object"]=>
object(stdClass)#1 (0) {
}
["resource"]=>
resource(4) of type (stream)
["null"]=>
NULL
}
Print_r(上面例子中的$debug_printr):
Array
(
[bool] =>
[int] => 1
[float] => 3.14
[string] => hello world
[array] => Array
(
)
[object] => stdClass Object
(
)
[resource] => Resource id #4
[null] =>
)
注意:var_export不处理循环引用
如果你试图转储一个循环引用的变量,调用var_export将导致一个PHP警告:
$circular = array();
$circular['self'] =& $circular;
var_export($circular);
结果:
Warning: var_export does not handle circular references in example.php on line 3
array (
'self' =>
array (
'self' => NULL,
),
)
另一方面,var_dump和print_r在遇到循环引用时会输出字符串*RECURSION*。
如果希望在运行时查看变量的内容,可以考虑使用XDebug等真正的调试器。这样就不需要弄乱源代码,即使普通用户访问您的应用程序,也可以使用调试器。他们不会注意到的。
这里是完整的解决方案作为一个函数:
function varDumpToString ($var)
{
ob_start();
var_dump($var);
return ob_get_clean();
}
如果你使用PHP>=7.0.0
function return_var_dump(...$args): string
{
ob_start();
try {
var_dump(...$args);
return ob_get_clean();
} catch (\Throwable $ex) {
// PHP8 ArgumentCountError for 0 arguments, probably..
// in php<8 this was just a warning
ob_end_clean();
throw $ex;
}
}
或者如果你使用PHP >=5.3.0:
function return_var_dump(){
ob_start();
call_user_func_array('var_dump', func_get_args());
return ob_get_clean();
}
或者如果你使用的是PHP<5.3.0(这个函数实际上一直兼容PHP4)
function return_var_dump(){
$args = func_get_args(); // For <5.3.0 support ...
ob_start();
call_user_func_array('var_dump', $args);
return ob_get_clean();
}
(在5.3.0之前,如果直接将func_get_args作为另一个函数调用的参数使用,则有一个错误,因此您必须将它放在变量中并使用变量,而不是直接将其作为参数使用..)
PHP手册:
此函数显示关于一个或多个表达式的结构化信息,其中包括表达式的类型和值。
因此,下面是PHP的var_dump()的实际返回版本,它实际上接受一个变长参数列表:
function var_dump_str()
{
$argc = func_num_args();
$argv = func_get_args();
if ($argc > 0) {
ob_start();
call_user_func_array('var_dump', $argv);
$result = ob_get_contents();
ob_end_clean();
return $result;
}
return '';
}
从http://htmlexplorer.com/2015/01/assign-output-var_dump-print_r-php-variable.html:
Var_dump和print_r函数只能直接输出到浏览器。所以这些函数的输出只能通过php的输出控制函数来检索。下面的方法可能对保存输出有用。 函数assignVarDumpValueToString($object ob_start (); var_dump($对象); $result = ob_get_clean(); 返回结果美元; }
Ob_get_clean()只能清除最后输入到内部缓冲区的数据。所以 如果您有多个条目,Ob_get_contents方法将非常有用。
来源与上文相同:
函数varDumpToErrorLog($var=null){ ob_start ();//开始读取内部缓冲区 var_dump ($ var); $grabbed_information = ob_get_contents();//将内部缓冲区内容分配给变量 ob_end_clean ();//清除内部缓冲区。 error_log ($ grabbed_information);//保存信息到error_log }
这可能有点跑题了。
我正在寻找一种方法将这类信息写入我的PHP-FPM容器的Docker日志中,并提出了下面的代码片段。我相信Docker PHP-FPM用户可以使用。
fwrite(fopen('php://stdout', 'w'), var_export($object, true));
我真的很喜欢var_dump()的详细输出,对var_export()的或print_r()的输出不满意,因为它没有提供尽可能多的信息(例如数据类型缺失,长度缺失)。
为了编写安全和可预测的代码,有时区分空字符串和null是有用的。或者在1和true之间。或者在null和false之间。我希望输出中有我的数据类型。
虽然很有帮助,但在现有的响应中,我没有找到一个干净简单的解决方案,可以将var_dump()的彩色输出转换为人类可读的输出,转换为一个没有html标记并包含var_dump()的所有细节的字符串。
注意,如果您有一个彩色的var_dump(),这意味着您已经安装了Xdebug,它会覆盖php的默认var_dump()来添加html颜色。
出于这个原因,我创造了这个轻微的变化,给我所需要的:
function dbg_var_dump($var)
{
ob_start();
var_dump($var);
$result = ob_get_clean();
return strip_tags(strtr($result, ['=>' => '=>']));
}
返回下面的nice字符串:
array (size=6)
'functioncall' => string 'add-time-property' (length=17)
'listingid' => string '57' (length=2)
'weekday' => string '0' (length=1)
'starttime' => string '00:00' (length=5)
'endtime' => string '00:00' (length=5)
'price' => string '' (length=0)
希望它能帮助到别人。
长字符串:只需使用echo($var);而不是dump($var);
对象或数组:var_dump(“< >之前”.json_encode ($ var)。”< / >之前);