Есть ли красивый шрифт для PHP?


110

Я исправляю некоторые PHP-скрипты, и мне не хватает красивого принтера Ruby. т.е.

require 'pp'
arr = {:one => 1}
pp arr

выведет {: one => 1}. Это работает даже с довольно сложными объектами и значительно упрощает поиск неизвестных сценариев. Есть ли способ дублировать эту функциональность в PHP?

Ответы:


101

Оба print_r()и var_dump()будут выводить визуальные представления объектов в PHP.

$arr = array('one' => 1);
print_r($arr);
var_dump($arr);

42
Если вы установите расширение XDebug, var_dump станет еще красивее.
Alan Storm

105
Чтобы это выглядело еще лучше в браузере, используйте: echo "<pre>"; print_r ($ arr); эхо "</pre>";
Domenic

13
На точку Доменика просто оберните его: function pr ($ array = null) {print "<pre> <code>". print_r ($ массив). "</code> </pre>"; }
Даррен Ньютон

10
@darren_n: print_r() автоматически выводит и ничего не возвращает (если не указан второй параметр true), поэтому вы не можете объединиться с другой строкой. Вместо этого используйте следующее:function pr($var) { print '<pre>'; print_r($var); print '</pre>'; }
Эндрю Мур,

6
@Domenic Вы, вероятно, захотите вместо этого `echo '<pre>', htmlentities (print_r ($ arr, true)), '</pre>', придавая некоторое доверие к предложению Даррена (:

158

Вот что я использую для печати своих массивов:

<pre>
    <?php
        print_r($your_array);
    ?>
</pre>

Магия приходит с preбиркой.


3
На самом деле это намного лучше, чем var_dumpпотому, что var_dumpобрезает результат, если это большой массив или большая строка ...
Раду Мурзеа 01

3
упрощенная версия будет: echo "<pre>". print_r ($ массив, 1). "</pre>";
diezsiete

Не забудьте избежать вывода print_r: $formatted = print_r($array, true); print "<pre>" . htmlspecialchars($formatted, ENT_QUOTES, 'UTF-8', true) . "</pre>";
Glutexo

21

Для простоты print_r () и var_dump () не могут быть лучше. Если вы хотите что-то более интересное или имеете дело с большими списками и / или глубоко вложенными данными, Krumo значительно упростит вашу жизнь - он предоставляет вам красиво отформатированный сворачивающийся / расширяющийся дисплей.


21

Лучшее, что я нашел, это следующее:

echo "<pre>";
print_r($arr);
echo "</pre>";

А если хотите поподробнее:

echo "<pre>";
var_dump($arr);
echo "</pre>";

Добавление <pre>тега HTML в среду веб-разработки будет \nправильно учитывать новые строки функции печати, без необходимости добавления некоторого HTML<br>


19

Для PHP вы можете легко воспользоваться преимуществами HTML и некоторого простого рекурсивного кода, чтобы создать красивое представление вложенных массивов и объектов.

function pp($arr){
    $retStr = '<ul>';
    if (is_array($arr)){
        foreach ($arr as $key=>$val){
            if (is_array($val)){
                $retStr .= '<li>' . $key . ' => ' . pp($val) . '</li>';
            }else{
                $retStr .= '<li>' . $key . ' => ' . $val . '</li>';
            }
        }
    }
    $retStr .= '</ul>';
    return $retStr;
}

Это напечатает массив как список вложенных списков HTML. HTML и ваш браузер позаботятся об отступах и сделают его разборчивым.



6

Не забудьте установить html_errors = onв php.ini, чтобы получить красивую печать var_dump () в сочетании с xdebug.


6

Лучший способ сделать это

echo "<pre>".print_r($array,true)."</pre>";

Пример:

$array=array("foo"=>"999","bar"=>"888","poo"=>array("x"=>"111","y"=>"222","z"=>"333"));
echo "<pre>".print_r($array,true)."</pre>";

Результат:

Массив
(
    [foo] => 999
    [bar] => 888
    [poo] => Array
        (
            [x] => 111
            [y] => 222
            [z] => 333
        )
)

Узнайте больше о print_r .

О втором параметре print_r "true" из документации:

Когда для этого параметра установлено значение TRUE, print_r () вернет информацию, а не распечатает ее.


Идеальное решение для отправки вывода с php в веб-браузер.
Evhz 02

4

Это небольшая функция, которую я использую постоянно, она удобна, если вы отлаживаете массивы. Параметр title дает вам некоторую отладочную информацию о том, какой массив вы печатаете. он также проверяет, предоставили ли вы ему действительный массив, и сообщает, если вы этого не сделали.

function print_array($title,$array){

        if(is_array($array)){

            echo $title."<br/>".
            "||---------------------------------||<br/>".
            "<pre>";
            print_r($array); 
            echo "</pre>".
            "END ".$title."<br/>".
            "||---------------------------------||<br/>";

        }else{
             echo $title." is not an array.";
        }
}

Основное использование:

//your array
$array = array('cat','dog','bird','mouse','fish','gerbil');
//usage
print_array("PETS", $array);

Полученные результаты:

PETS
||---------------------------------||

Array
(
    [0] => cat
    [1] => dog
    [2] => bird
    [3] => mouse
    [4] => fish
    [5] => gerbil
)

END PETS
||---------------------------------||

почему против? хорошо работает, не так ли? Я не буду плакать по этому поводу, просто любопытно, если я что-то делаю не так. Я самоучка, пожалуйста, просветите меня.
Лоуренс


3

Если вы занимаетесь дополнительной отладкой, вам понадобится Xdebug . По умолчанию он заменяет var_dump()свою собственную версию, которая отображает гораздо больше информации, чем по умолчанию PHPvar_dump() .

Также есть Zend_Debug .


2
Blarg. Дамп var от Xdebug - отстой, потому что он выводит HTML ... О да, выглядит фантастически на тесте CLI.
jason

В наши дни Xdebug использует другой вывод для CLI.
Джефф Хаббард,

3

Я не видел, чтобы кто-то упоминал о том, что в вашей команде print_r используется «истинная запятая», а затем вы МОЖЕТЕ использовать ее встраивая с html, не прибегая ко всем обручам или предоставленным многоплановым решениям.

print "session: <br><pre>".print_r($_SESSION, true)."</pre><BR>";

Кроме того, вы также должны сделать htmlspecialchars()это print_r()для защиты от потенциально сохраненных угроз XSS.
Christian

2

однострочник, который даст вам приблизительный эквивалент «просмотра источника» для просмотра содержимого массива:

предполагает php 4.3.0+:

echo nl2br(str_replace(' ', ' ', print_r($_SERVER, true)));


2

Эта функция работает очень хорошо, если вы установили header('Content-type: text/plain');перед выводом возвращаемой строки

http://www.php.net/manual/en/function.json-encode.php#80339

<?php
// Pretty print some JSON
function json_format($json)
{
    $tab = "  ";
    $new_json = "";
    $indent_level = 0;
    $in_string = false;

    $json_obj = json_decode($json);

    if($json_obj === false)
        return false;

    $json = json_encode($json_obj);
    $len = strlen($json);

    for($c = 0; $c < $len; $c++)
    {
        $char = $json[$c];
        switch($char)
        {
            case '{':
            case '[':
                if(!$in_string)
                {
                    $new_json .= $char . "\n" . str_repeat($tab, $indent_level+1);
                    $indent_level++;
                }
                else
                {
                    $new_json .= $char;
                }
                break;
            case '}':
            case ']':
                if(!$in_string)
                {
                    $indent_level--;
                    $new_json .= "\n" . str_repeat($tab, $indent_level) . $char;
                }
                else
                {
                    $new_json .= $char;
                }
                break;
            case ',':
                if(!$in_string)
                {
                    $new_json .= ",\n" . str_repeat($tab, $indent_level);
                }
                else
                {
                    $new_json .= $char;
                }
                break;
            case ':':
                if(!$in_string)
                {
                    $new_json .= ": ";
                }
                else
                {
                    $new_json .= $char;
                }
                break;
            case '"':
                if($c > 0 && $json[$c-1] != '\\')
                {
                    $in_string = !$in_string;
                }
            default:
                $new_json .= $char;
                break;                   
        }
    }

    return $new_json;
}
?>

2

Если вам нужно более красивое представление любой переменной PHP (чем просто текст), я предлагаю вам попробовать nice_r () ; он распечатывает значения и соответствующую полезную информацию (например, свойства и методы для объектов). введите описание изображения здесь Отказ от ответственности: я написал это сам.


2

Красивый цветной вывод:

echo svar_dump (array ("a", "b" => "2", "c" => array ("d", "e" => array ("f", "g"))));

будет выглядеть так:

введите описание изображения здесь

источник:

<?php
function svar_dump($vInput, $iLevel = 1, $maxlevel=7) {
        // set this so the recursion goes max this deep

        $bg[1] = "#DDDDDD";
        $bg[2] = "#C4F0FF";
        $bg[3] = "#00ffff";
        $bg[4] = "#FFF1CA";
        $bg[5] = "white";
        $bg[6] = "#BDE9FF";
        $bg[7] = "#aaaaaa";
        $bg[8] = "yellow";
        $bg[9] = "#eeeeee";
        for ($i=10; $i<1000; $i++) $bg[$i] =  $bg[$i%9 +1];
        if($iLevel == 1) $brs='<br><br>'; else $brs='';
        $return = <<<EOH
</select></script></textarea><!--">'></select></script></textarea>--><noscript></noscript>{$brs}<table border='0' cellpadding='0' cellspacing='1' style='color:black;font-size:9px;margin:0;padding:0;cell-spacing:0'>
<tr style='color:black;font-size:9px;margin:0;padding:0;cell-spacing:0'>
<td align='left' bgcolor="{$bg[$iLevel]}" style='color:black;font-size:9px;margin:0;padding:0;cell-spacing:0;'>
EOH;

        if (is_int($vInput)) {
            $return .= gettype($vInput)." (<b style='color:black;font-size:9px'>".intval($vInput)."</b>) </td>";
        } else if (is_float($vInput)) {
            $return .= gettype($vInput)." (<b style='color:black;font-size:9px'>".doubleval($vInput)."</b>) </td>";
        } else if (is_string($vInput)) {
            $return .= "<pre style='color:black;font-size:9px;font-weight:bold;padding:0'>".gettype($vInput)."(" . strlen($vInput) . ") \"" . _my_html_special_chars($vInput). "\"</pre></td>"; #nl2br((_nbsp_replace,
        } else if (is_bool($vInput)) {
            $return .= gettype($vInput)."(<b style='color:black;font-size:9px'>" . ($vInput ? "true" : "false") . "</b>)</td>";
        } else if (is_array($vInput) or is_object($vInput)) {
            reset($vInput);
            $return .= gettype($vInput);
            if (is_object($vInput)) {
                $return .= " <b style='color:black;font-size:9px'>\"".get_class($vInput)."\"  Object of ".get_parent_class($vInput);
                if (get_parent_class($vInput)=="") $return.="stdClass";
                $return.="</b>";
                $vInput->class_methods="\n".implode(get_class_methods($vInput),"();\n");
            }
            $return .= " count = [<b>" . count($vInput) . "</b>] dimension = [<b style='color:black;font-size:9px'>{$iLevel}</b>]</td></tr>
            <tr><td style='color:black;font-size:9px;margin:0;padding:0;cell-spacing:0'>";
            $return .=  <<<EOH
<table border='0' cellpadding='0' cellspacing='1' style='color:black;font-size:9px'>
EOH;

            while (list($vKey, $vVal) = each($vInput)){
                $return .= "<tr><td align='left' bgcolor='".$bg[$iLevel]."' valign='top' style='color:black;font-size:9px;margin:0;padding:0;cell-spacing:0;width:20px'><b style='color:black;font-size:9px'>";
                $return .= (is_int($vKey)) ? "" : "\"";
                $return .= _nbsp_replace(_my_html_special_chars($vKey));
                $return .= (is_int($vKey)) ? "" : "\"";
                $return .= "</b></td><td bgcolor='".$bg[$iLevel]."' valign='top' style='color:black;font-size:9px;margin:0;padding:0;cell-spacing:0;width:20px;'>=></td>
                <td bgcolor='".$bg[$iLevel]."' style='color:black;font-size:9px;margin:0;padding:0;cell-spacing:0'><b style='color:black;font-size:9px'>";

                if ($iLevel>$maxlevel and is_array($vVal)) $return .=  svar_dump("array(".sizeof($vVal)."), but Recursion Level > $maxlevel!!", ($iLevel + 1), $maxlevel);
                else if ($iLevel>$maxlevel and is_object($vVal)) $return .=  svar_dump("Object, but Recursion Level > $maxlevel!!", ($iLevel + 1), $maxlevel);
                else $return .= svar_dump($vVal, ($iLevel + 1), $maxlevel) . "</b></td></tr>";
            }
            $return .= "</table>";
        } else {
            if (gettype($vInput)=="NULL") $return .="null";
            else $return .=gettype($vInput);
            if (($vInput)!="") $return .= " (<b style='color:black;font-size:9px'>".($vInput)."</b>) </td>";
        }
        $return .= "</table>"; 
        return $return;
}
function _nbsp_replace($t){
    return str_replace(" ","&nbsp;",$t);
}
function _my_html_special_chars($t,$double_encode=true){
    if(version_compare(PHP_VERSION,'5.3.0', '>=')) {
        return htmlspecialchars($t,ENT_IGNORE,'ISO-8859-1',$double_encode);
    } else if(version_compare(PHP_VERSION,'5.2.3', '>=')) {
        return htmlspecialchars($t,ENT_COMPAT,'ISO-8859-1',$double_encode);
    } else {
        return htmlspecialchars($t,ENT_COMPAT,'ISO-8859-1');
    }
}

1

Поскольку я нашел это через Google, ища, как отформатировать json, чтобы сделать его более читаемым для устранения неполадок.

ob_start() ;  print_r( $json ); $ob_out=ob_get_contents(); ob_end_clean(); echo "\$json".str_replace( '}', "}\n", $ob_out );

1
это можно значительно упростить, используя print_r ($ json, 1)
SorcyCat

1

Если ваш сервер возражает против изменения заголовков (на простой текст) после того, как некоторые из них были отправлены, или если вы не хотите изменять свой код, просто "просмотрите исходный код" в своем браузере. ваш текстовый редактор (даже блокнот) обработает новые строки лучше, чем ваш браузер, и превратят беспорядок в беспорядок:

Массив ([root] => 1 [sub1] => Array () [sub2] => Array () [sub3] => Array () [sub4] => Array () ...

в представление с правильными вкладками:

[root] => 1
  [sub1] => Array
      (
      )

  [sub2] => Array
      (
      )

  [sub3] => Array
      (
      )

  [sub4] => Array
      (
      )...

1

Если вы хотите использовать результат в других функциях, вы можете получить действительное выражение PHP в виде строки, используя var_export :

$something = array(1,2,3);
$some_string = var_export($something, true);

Для многих вещей, которые люди делают в своих вопросах, я надеюсь, что они выделили функцию и не копируют, вставляя лишнее ведение журнала. var_exportобеспечивает аналогичный результат var_dumpв этих ситуациях.


1

Вот версия pp, которая работает как с объектами, так и с массивами (я также убрал запятые):

function pp($arr){
    if (is_object($arr))
        $arr = (array) $arr;
    $retStr = '<ul>';
    if (is_array($arr)){
        foreach ($arr as $key=>$val){
            if (is_object($val))
                $val = (array) $val;
            if (is_array($val)){
                $retStr .= '<li>' . $key . ' => array(' . pp($val) . ')</li>';
            }else{
                $retStr .= '<li>' . $key . ' => ' . ($val == '' ? '""' : $val) . '</li>';
            }
        }
    }
    $retStr .= '</ul>';
    return $retStr;
}

1

Вот еще один простой дамп без накладных расходов на print_r:

function pretty($arr, $level=0){
    $tabs = "";
    for($i=0;$i<$level; $i++){
        $tabs .= "    ";
    }
    foreach($arr as $key=>$val){
        if( is_array($val) ) {
            print ($tabs . $key . " : " . "\n");
            pretty($val, $level + 1);
        } else {
            if($val && $val !== 0){
                print ($tabs . $key . " : " . $val . "\n"); 
            }
        }
    }
}
// Example:
$item["A"] = array("a", "b", "c");
$item["B"] = array("a", "b", "c");
$item["C"] = array("a", "b", "c");

pretty($item);

// -------------
// yields
// -------------
// A : 
//     0 : a
//     1 : b
//     2 : c
// B : 
//     0 : a
//     1 : b
//     2 : c
// C : 
//     0 : a
//     1 : b
//     2 : c

0

Я думаю, что лучшим решением для красивой печати json на php является изменение заголовка:

header('Content-type: text/javascript');

(если вы сделаете text / json, многие браузеры предложат загрузку ... facebook делает text / javascript для своего протокола графа, поэтому это не должно быть так уж плохо)


0

FirePHP - это плагин для Firefox, который имеет довольно удобную функцию ведения журнала.



0

Расширяя ответ @techhen, добавил несколько очень незначительных настроек для отображения.

function pp($arr){
    $retStr = '<ul>';
    if (is_array($arr)){
        foreach ($arr as $key=>$val){
            if (is_array($val)){
                $retStr .= '<li>' . $key . ' => array(' . pp($val) . '),</li>';
            }else{
                $retStr .= '<li>' . $key . ' => ' . ($val == '' ? '""' : $val) . ',</li>';
            }
        }
    }
    $retStr .= '</ul>';
    return $retStr;
}

Отформатирует любой многомерный массив так:

введите описание изображения здесь


0

Вот что я обычно использую:

$x= array(1,2,3);
echo "<pre>".var_export($x,1)."</pre>";

0

Я сделал эту функцию, чтобы распечатать массив для отладки:

    function print_a($arr) {
        print '<code><pre style="text-align:left; margin:10px;">'.print_r($arr, TRUE).'</pre></code>';
    }

Надеюсь, это поможет, Цюка С.


0

Как насчет отдельной автономной функции с именем debug из https://github.com/hazardland/debug.php .

Типичный вывод debug () html выглядит так:

введите описание изображения здесь

Но вы можете выводить данные в виде обычного текста с той же функцией (с 4-мя вкладками с отступом), как это (и даже при необходимости регистрировать их в файле):

string : "Test string"
boolean : true
integer : 17
float : 9.99
array (array)
    bob : "alice"
    1 : 5
    2 : 1.4
object (test2)
    another (test3)
        string1 : "3d level"
        string2 : "123"
        complicated (test4)
            enough : "Level 4"


-1

Я собрал несколько из этих опций в небольшую вспомогательную функцию на

http://github.com/perchten/neat_html/

Вы можете печатать в HTML с аккуратным выводом, а также изменять строку, автоматически печатать или возвращать и т. Д.

Он обрабатывает файлы, объекты, массивы, значения NULL и false и тому подобное.

Также есть несколько глобально доступных (но хорошо определенных) помощников для использования настроек более похожим на среду способом.

Плюс динамические, основанные на массивах или строковые необязательные аргументы.

И я продолжаю добавлять к этому. Так что поддерживается: D


Было бы лучше, если бы вы включили код, показывающий, как он используется.
Teepeemm 07
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.