web-dev-qa-db-ja.com

PHP用のきれいなプリントはありますか?

いくつかのPHPスクリプトを修正していますが、Rubyのきれいなプリンターがありません。つまり.

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

{:one => 1}を出力します。これはかなり複雑なオブジェクトでも機能し、未知のスクリプトをより簡単に掘り下げます。 PHPでこの機能を複製する方法はありますか?

110
Aaron Lee

print_r()var_dump() の両方は、PHP内のオブジェクトの視覚的表現を出力します。

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

これは私の配列を印刷するために使用するものです:

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

マジックにはpreタグが付属しています。

158
Joel Hernandez

簡単にするために、 print_r() および var_dump() は負けません。少し手の込んだものが必要な場合、または大きなリストや深くネストされたデータを処理している場合は、 Krumo を使用すると、作業がはるかに簡単になります。

21

私がまだ見つけた最高のものはこれです:

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

さらに詳細が必要な場合:

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

Web開発環境で<pre> HTMLタグを追加すると、HTML \nを追加することなく、印刷機能の改行<br>が正しく考慮されます。

21

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とブラウザがインデントを処理し、読みやすくします。

19
Stephen Katulka

Print_rはどうですか?

http://www.php.net/print_r

7
Turnor

Xdebugと組み合わせてvar_dump()をきれいに印刷するには、php.iniでhtml_errors = onを設定することを忘れないでください。

6
pfrenssen

これを行う最善の方法は

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] =>配列

[x] => 111
[y] => 222
[z] => 333

print_r の詳細をご覧ください。

ドキュメントのprint_rの2番目のパラメーター「true」について:

このパラメーターがTRUEに設定されている場合、print_r()は情報を印刷せずに返します。

6
Mouneer

これは、配列をデバッグする場合に便利な小さな機能です。 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
||---------------------------------||
4
Laurence

Print_rコマンドで "コンマtrue"を実行することを言及した人はいませんでした。その後、提供されたすべてのフープや複雑な外観のソリューションを介さずに、htmlでインラインで使用できます。

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

さらにデバッグを行う場合は、 Xdebug が不可欠です。デフォルトでは、var_dump()を独自のバージョン でオーバーライドし、PHPのデフォルトのvar_dump() よりも多くの情報を表示します。

Zend_Debug もあります。

3
raspi
error_log(print_r($variable,true));

windowsのsyslogまたはイベントログに送信する

3
Question Mark

配列の内容を表示するための「ソースの表示」にほぼ相当するワンライナー:

php 4.3.0以降を想定しています:

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

2
mxmader

この関数は、戻り文字列を出力する前に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
Nathan Witt

(単なるテキストよりも)PHP変数のより適切な表現が必要な場合は、 Nice_r() ;を試してみることをお勧めします。値と関連する有用な情報(例:オブジェクトのプロパティとメソッド)を出力します。 enter image description here 免責事項:私はこれを自分で書きました。

2
Christian

素敵な色の出力:

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

次のようになります。

enter image description here

ソース:

<?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');
    }
}
2
rubo77

オブジェクトと配列の両方で機能する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
Serge Goldstein

次に、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
1
bob

トラブルシューティングのためにjsonをより読みやすくするためにjsonをフォーマットする方法をGoogleで検索して見つけたので。

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

結果を他の関数で使用する場合、 var_export を使用して、有効なPHP式を文字列として取得できます。

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

人々が質問でしている多くのことについて、私は彼らが機能を捧げて、余分なログを貼り付けてコピーしないことを望んでいます。 var_exportは、これらの状況でvar_dumpと同様の出力を実現します。

1
Aram Kocharyan

サーバーがあなたに反対する場合、送信後にヘッダーをプレーンテキストに変更する場合、またはコードを変更したくない場合は、ブラウザから「ソースを表示」-テキストエディター(メモ帳も)は、ブラウザーよりも新しい行を処理し、混乱をもたらします。

配列([ルート] => 1 [sub1] =>配列()[sub2] =>配列()[sub3] =>配列()[sub4] =>配列()...

適切にタブ化された表現に:

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

  [sub2] => Array
      (
      )

  [sub3] => Array
      (
      )

  [sub4] => Array
      (
      )...
1
adamdport

@stephenの答えを拡張して、表示目的のためにいくつかの非常に小さな調整を追加しました。

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;
}

次のように多次元配列をフォーマットします。

enter image description here

0

これは私が通常使用するものです:

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

https://github.com/hazardland/debug.php からdebugという名前の単一のスタンドアロン関数はどうでしょうか。

典型的なdebug()html出力は次のようになります。

enter image description here

ただし、次のように(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"
0
BIOHAZARD

PHPでjsonをきれいに印刷するための最善の解決策は、ヘッダーを変更することだと思います。

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

(text/jsonを実行すると、多くのブラウザがダウンロードを要求します... facebookはグラフプロトコルのtext/javascriptを実行するため、それほど悪くないはずです)

0
Grant Miller

FirePHPは、非常にきれいなログ機能を備えたfirefoxプラグインです。

0
PHPst
    <?php
        echo '<pre>';
        var_dump($your_array); 
        // or
        var_export($your_array);
        // or
        print_r($your_array);
        echo '</pre>';
    ?>

またはREFのような外部ライブラリを使用します: https://github.com/digitalnature/php-ref

0
Foad Tahmasebi

デバッグ用の配列を出力するためにこの関数を作成しました:

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

Tziuka S.さんのお役に立てばと思います.

0
tziuka

PHP 5.4では、関数json_encodeを使用している場合、JSON_PRETTY_PRINTを使用できます。

json_encode(array('one', 'two', 'three'), JSON_PRETTY_PRINT);

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

0