PHPでJSONをきれいに印刷する


588

JSONデータを別のスクリプトにフィードするPHPスクリプトを作成しています。私のスクリプトはデータを大きな連想配列に構築し、を使用してデータを出力しますjson_encode。次にスクリプトの例を示します。

$data = array('a' => 'apple', 'b' => 'banana', 'c' => 'catnip');
header('Content-type: text/javascript');
echo json_encode($data);

上記のコードは次の出力を生成します。

{"a":"apple","b":"banana","c":"catnip"}

これは、データ量が少ない場合に最適ですが、次のような方法をお勧めします。

{
    "a": "apple",
    "b": "banana",
    "c": "catnip"
}

醜いハックなしでこれをPHPで行う方法はありますか?Facebookの誰かがそれを理解したようです。


26
5.4前にPHPのために、あなたはにフォールバックを使用することができますupgradephpとしてup_json_encode($data, JSON_PRETTY_PRINT);
マリオ

6
使用ヘッダ(「コンテンツタイプ:アプリケーション/ JSON」)。 ブラウザの
見栄えをよくする

4
2018年7月現在、Content-Type: application/jsonヘッダーを送信するだけで、Firefoxは独自の内部JSONパーサーを使用して結果を表示し、Chromeはプレーンテキストを表示します。+1 Firefox!
andreszs

回答:


1127

PHP 5.4はJSON_PRETTY_PRINTjson_encode()呼び出しで使用するオプションを提供します。

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

<?php
...
$json_string = json_encode($data, JSON_PRETTY_PRINT);

33
おかげで、これは今それを行うための最良の方法です。私がこの質問をしたとき、私はphp 5.4を持っていませんでした...
Zach Rattner

9
5.5.3ここでは、実際のインデントではなく、文字間にわずかなスペースを追加しているようです。

35
JSONにはHTMLの改行を含めることはできませんが、JSONでは改行文字が有効です。JSONをWebページに表示する場合は、改行文字を自分で文字列置換するか、JSONを<pre> ... </ pre>要素に配置します。構文リファレンスについては、json.orgを参照してください。
ekillaby

13
セット応答に忘れてはいけないContent-Typeapplication/json、ブラウザはうまくきれいに印刷JSONを表示したい場合。
Pijusn 2015年

6
@countfloortilesこれは直接機能しません。出力を<pre>タグで囲む必要があります<?php ... $json_string = json_encode($data, JSON_PRETTY_PRINT); echo "<pre>".$json_string."<pre>";
Salman Mohammad

187

この関数は、JSON文字列を受け取り、非常に読みやすくインデントします。また、収束する必要があります。

prettyPrint( $json ) === prettyPrint( prettyPrint( $json ) )

入力

{"key1":[1,2,3],"key2":"value"}

出力

{
    "key1": [
        1,
        2,
        3
    ],
    "key2": "value"
}

コード

function prettyPrint( $json )
{
    $result = '';
    $level = 0;
    $in_quotes = false;
    $in_escape = false;
    $ends_line_level = NULL;
    $json_length = strlen( $json );

    for( $i = 0; $i < $json_length; $i++ ) {
        $char = $json[$i];
        $new_line_level = NULL;
        $post = "";
        if( $ends_line_level !== NULL ) {
            $new_line_level = $ends_line_level;
            $ends_line_level = NULL;
        }
        if ( $in_escape ) {
            $in_escape = false;
        } else if( $char === '"' ) {
            $in_quotes = !$in_quotes;
        } else if( ! $in_quotes ) {
            switch( $char ) {
                case '}': case ']':
                    $level--;
                    $ends_line_level = NULL;
                    $new_line_level = $level;
                    break;

                case '{': case '[':
                    $level++;
                case ',':
                    $ends_line_level = $level;
                    break;

                case ':':
                    $post = " ";
                    break;

                case " ": case "\t": case "\n": case "\r":
                    $char = "";
                    $ends_line_level = $new_line_level;
                    $new_line_level = NULL;
                    break;
            }
        } else if ( $char === '\\' ) {
            $in_escape = true;
        }
        if( $new_line_level !== NULL ) {
            $result .= "\n".str_repeat( "\t", $new_line_level );
        }
        $result .= $char.$post;
    }

    return $result;
}

84

多くのユーザーがあなたが使用することを提案しました

echo json_encode($results, JSON_PRETTY_PRINT);

それは絶対に正しいです。しかし、それだけでは不十分です。ブラウザはデータのタイプを理解する必要があります。データをユーザーにエコーする直前にヘッダーを指定できます。

header('Content-Type: application/json');

これにより、適切にフォーマットされた出力が得られます。

または、拡張機能が必要な場合は、JSONView for Chromeを使用できます。


3
ヘッダー設定するだけで、Firefoxは独自の内部JSONデバッグパーサーを使用して完全に表示します。JSONコンテンツに触れる必要はありません。ありがとうございました!!
andreszs

1
クロームでも動作します。ありがとう。
ドンディランガ

41

同じ問題がありました。

とにかく、私はここでjsonフォーマットコードを使用しました:

http://recursive-design.com/blog/2008/03/11/format-json-with-php/

私が必要とするものにうまく機能します。

そしてよりメンテナンスされたバージョン:https : //github.com/GerHobbelt/nicejson-php


私はgithub.com/GerHobbelt/nicejson-phpを試しましたが、PHP 5.3でうまく動作します。
ファルケン教授の契約が2013年

1
PHP7.0以上を使用していて、カスタムインデントでJSONをきれいに出力する必要がある場合は、localheinz.com / blog / 2018/01/04 /…が役立つはずです。
localheinz 2018年

40

この質問は、連想配列をきれいにフォーマットされたJSON文字列にエンコードする方法を尋ねているので、これは質問に直接答えることはできませんが、すでにJSON形式の文字列がある場合は、簡単に作成できますデコードして再エンコードする(PHP> = 5.4が必要):

$json = json_encode(json_decode($json), JSON_PRETTY_PRINT);

例:

header('Content-Type: application/json');
$json_ugly = '{"a":1,"b":2,"c":3,"d":4,"e":5}';
$json_pretty = json_encode(json_decode($json_ugly), JSON_PRETTY_PRINT);
echo $json_pretty;

これは出力します:

{
    "a": 1,
    "b": 2,
    "c": 3,
    "d": 4,
    "e": 5
}

おかげで、これをphpブロックの先頭に追加した場合にのみ機能します... header( 'Content-Type:application / json');
DeyaEldeen

2
@DeyaEldeenそのヘッダーを使用しない場合、PHPはブラウザーにHTMLを送信していることを通知するので、フォーマットされたJSON文字列を表示するにはページのソースを表示する必要があります。私はそれが理解されたと思いましたが、私はそうは思いません。回答に追加しました。
マイク

そして、unix / linuxシェルでログ/ファイルをテーリング/レビューする人は誰でも、これがここでの解決策です!見栄えがよく、@マイクは読みやすくします!。
fusion27

@ fusion27どのログファイルを参照しているのか本当にわかりません。JSONで何かをログに記録するプログラムを聞いたことがありません。
マイク

@マイク、それは私がリクエスト本文(シリアル化されたJSON文字列)をテキストファイルにPOSTして追加したホイップアップでダーティなPHPであり、次にそれをUNIXシェルにテイルしてライブPOSTを見ることができます。私はあなたのトリックを使ってJSONをフォーマットし、テキストファイルをより使いやすくしています。
Fusion27

25

いくつかの答えを一緒に接着すると、既存のjsonに対する私のニーズに適合します

Code:
echo "<pre>"; 
echo json_encode(json_decode($json_response), JSON_PRETTY_PRINT); 
echo "</pre>";

Output:
{
    "data": {
        "token_type": "bearer",
        "expires_in": 3628799,
        "scopes": "full_access",
        "created_at": 1540504324
    },
    "errors": [],
    "pagination": {},
    "token_type": "bearer",
    "expires_in": 3628799,
    "scopes": "full_access",
    "created_at": 1540504324
}

3
ここでは、これを行うために少しラッパー関数があります:function json_print($json) { return '<pre>' . json_encode(json_decode($json), JSON_PRETTY_PRINT) . '</pre>'; }
ダニー・ベケット

11

私はComposerからコードを取得しました:https : //github.com/composer/composer/blob/master/src/Composer/Json/JsonFile.php and nicejson:https : //github.com/GerHobbelt/nicejson-php/blob /master/nicejson.php Composerコードは、5.3から5.4にスムーズに更新されますが、nicejsonがjson文字列を取得するのに対してオブジェクトをエンコードするだけなので、私はそれらをマージしたので優れています。コードは、json文字列のフォーマットやオブジェクトのエンコードに使用できます。現在、Drupalモジュールで使用しています。

if (!defined('JSON_UNESCAPED_SLASHES'))
    define('JSON_UNESCAPED_SLASHES', 64);
if (!defined('JSON_PRETTY_PRINT'))
    define('JSON_PRETTY_PRINT', 128);
if (!defined('JSON_UNESCAPED_UNICODE'))
    define('JSON_UNESCAPED_UNICODE', 256);

function _json_encode($data, $options = 448)
{
    if (version_compare(PHP_VERSION, '5.4', '>='))
    {
        return json_encode($data, $options);
    }

    return _json_format(json_encode($data), $options);
}

function _pretty_print_json($json)
{
    return _json_format($json, JSON_PRETTY_PRINT);
}

function _json_format($json, $options = 448)
{
    $prettyPrint = (bool) ($options & JSON_PRETTY_PRINT);
    $unescapeUnicode = (bool) ($options & JSON_UNESCAPED_UNICODE);
    $unescapeSlashes = (bool) ($options & JSON_UNESCAPED_SLASHES);

    if (!$prettyPrint && !$unescapeUnicode && !$unescapeSlashes)
    {
        return $json;
    }

    $result = '';
    $pos = 0;
    $strLen = strlen($json);
    $indentStr = ' ';
    $newLine = "\n";
    $outOfQuotes = true;
    $buffer = '';
    $noescape = true;

    for ($i = 0; $i < $strLen; $i++)
    {
        // Grab the next character in the string
        $char = substr($json, $i, 1);

        // Are we inside a quoted string?
        if ('"' === $char && $noescape)
        {
            $outOfQuotes = !$outOfQuotes;
        }

        if (!$outOfQuotes)
        {
            $buffer .= $char;
            $noescape = '\\' === $char ? !$noescape : true;
            continue;
        }
        elseif ('' !== $buffer)
        {
            if ($unescapeSlashes)
            {
                $buffer = str_replace('\\/', '/', $buffer);
            }

            if ($unescapeUnicode && function_exists('mb_convert_encoding'))
            {
                // http://stackoverflow.com/questions/2934563/how-to-decode-unicode-escape-sequences-like-u00ed-to-proper-utf-8-encoded-cha
                $buffer = preg_replace_callback('/\\\\u([0-9a-f]{4})/i',
                    function ($match)
                    {
                        return mb_convert_encoding(pack('H*', $match[1]), 'UTF-8', 'UCS-2BE');
                    }, $buffer);
            } 

            $result .= $buffer . $char;
            $buffer = '';
            continue;
        }
        elseif(false !== strpos(" \t\r\n", $char))
        {
            continue;
        }

        if (':' === $char)
        {
            // Add a space after the : character
            $char .= ' ';
        }
        elseif (('}' === $char || ']' === $char))
        {
            $pos--;
            $prevChar = substr($json, $i - 1, 1);

            if ('{' !== $prevChar && '[' !== $prevChar)
            {
                // If this character is the end of an element,
                // output a new line and indent the next line
                $result .= $newLine;
                for ($j = 0; $j < $pos; $j++)
                {
                    $result .= $indentStr;
                }
            }
            else
            {
                // Collapse empty {} and []
                $result = rtrim($result) . "\n\n" . $indentStr;
            }
        }

        $result .= $char;

        // If the last character was the beginning of an element,
        // output a new line and indent the next line
        if (',' === $char || '{' === $char || '[' === $char)
        {
            $result .= $newLine;

            if ('{' === $char || '[' === $char)
            {
                $pos++;
            }

            for ($j = 0; $j < $pos; $j++)
            {
                $result .= $indentStr;
            }
        }
    }
    // If buffer not empty after formating we have an unclosed quote
    if (strlen($buffer) > 0)
    {
        //json is incorrectly formatted
        $result = false;
    }

    return $result;
}

これがそのやり方です!ネイティブが使用できない場合にのみ、独自の実装が実行されます。コードがPHP 5.4以降でのみ実行されることが確実な場合は、JSON_PRETTY_PRINTを使用することができます
Heroselohim

このソリューションでは、行関数($ match)でエラー(解析エラー:構文エラー、予期しないT_FUNCTION)が発生します
ARLabs


10

Firefoxを使用している場合は、JSONovichをインストールします。私が知っている実際のPHPソリューションではありませんが、開発目的/デバッグのためのトリックを行います。


3
これは、APIを開発する際の適切な解決策だと思います。すべてを読み取ることができ、バックエンドの動作(パフォーマンスを含む)を変更しないため、両方の世界で最高のデバッグが容易になります。
Daniel

それに同意し、色でうまくフォーマットされ、折りたたみも可能です。PHPを少し使って実現するよりもずっと良い
Matthew Lock

10

私はこれを使用しました:

echo "<pre>".json_encode($response, JSON_PRETTY_PRINT | JSON_UNESCAPED_UNICODE | JSON_UNESCAPED_SLASHES)."</pre>";

または、以下のようにphpヘッダーを使用します。

header('Content-type: application/json; charset=UTF-8');
echo json_encode($response, JSON_PRETTY_PRINT | JSON_UNESCAPED_UNICODE | JSON_UNESCAPED_SLASHES);

8

PHP> 5.4の簡単な方法:Facebookグラフのような

$Data = array('a' => 'apple', 'b' => 'banana', 'c' => 'catnip');
$json= json_encode($Data, JSON_PRETTY_PRINT);
header('Content-Type: application/json');
print_r($json);

ブラウザでの結果

{
    "a": "apple",
    "b": "banana",
    "c": "catnip"
}

@Madbreaks、それはphpファイルでうまく印刷されます、facebookのようにjsonファイルで書く必要はありません。
dknepa

6

およびオプションと<pre>組み合わせて使用します。json_encode()JSON_PRETTY_PRINT

<pre>
    <?php
    echo json_encode($dataArray, JSON_PRETTY_PRINT);
    ?>
</pre>

6

既存のJSON($ugly_json)がある場合

echo nl2br(str_replace(' ', '&nbsp;', (json_encode(json_decode($ugly_json), JSON_PRETTY_PRINT | JSON_UNESCAPED_SLASHES))));

5

カラーフル出力:Tiny Solution

コード:

$s = '{"access": {"token": {"issued_at": "2008-08-16T14:10:31.309353", "expires": "2008-08-17T14:10:31Z", "id": "MIICQgYJKoZIhvcIegeyJpc3N1ZWRfYXQiOiAi"}, "serviceCatalog": [], "user": {"username": "ajay", "roles_links": [], "id": "16452ca89", "roles": [], "name": "ajay"}}}';

$crl = 0;
$ss = false;
echo "<pre>";
for($c=0; $c<strlen($s); $c++)
{
    if ( $s[$c] == '}' || $s[$c] == ']' )
    {
        $crl--;
        echo "\n";
        echo str_repeat(' ', ($crl*2));
    }
    if ( $s[$c] == '"' && ($s[$c-1] == ',' || $s[$c-2] == ',') )
    {
        echo "\n";
        echo str_repeat(' ', ($crl*2));
    }
    if ( $s[$c] == '"' && !$ss )
    {
        if ( $s[$c-1] == ':' || $s[$c-2] == ':' )
            echo '<span style="color:#0000ff;">';
        else
            echo '<span style="color:#ff0000;">';
    }
    echo $s[$c];
    if ( $s[$c] == '"' && $ss )
        echo '</span>';
    if ( $s[$c] == '"' )
          $ss = !$ss;
    if ( $s[$c] == '{' || $s[$c] == '[' )
    {
        $crl++;
        echo "\n";
        echo str_repeat(' ', ($crl*2));
    }
}
echo $s[$c];

これにはいくつかのエラーがありましたが、これは非常に役に立ちました。直したところ、魅力的になり、機能もさほど大きくありません!アジェイに感謝
ダニエル

誰かがこれを使用したい場合は修正にコメントするだけです... 2番目と3番目のif条件に検証チェック$ c> 1を追加し、最後のエコーでis_array($ s)ifにラップします。それはそれをカバーするはずであり、初期化されていない文字列オフセットエラーを受け取るべきではありません。
ダニエル

5

次のようにjson文字列を渡すことで、switchステートメントのKendall Hopkinsの回答を少し変更して、見た目がきれいで見栄えの良い印刷を得ることができます。

function prettyPrint( $json ){

$result = '';
$level = 0;
$in_quotes = false;
$in_escape = false;
$ends_line_level = NULL;
$json_length = strlen( $json );

for( $i = 0; $i < $json_length; $i++ ) {
    $char = $json[$i];
    $new_line_level = NULL;
    $post = "";
    if( $ends_line_level !== NULL ) {
        $new_line_level = $ends_line_level;
        $ends_line_level = NULL;
    }
    if ( $in_escape ) {
        $in_escape = false;
    } else if( $char === '"' ) {
        $in_quotes = !$in_quotes;
    } else if( ! $in_quotes ) {
        switch( $char ) {
            case '}': case ']':
                $level--;
                $ends_line_level = NULL;
                $new_line_level = $level;
                $char.="<br>";
                for($index=0;$index<$level-1;$index++){$char.="-----";}
                break;

            case '{': case '[':
                $level++;
                $char.="<br>";
                for($index=0;$index<$level;$index++){$char.="-----";}
                break;
            case ',':
                $ends_line_level = $level;
                $char.="<br>";
                for($index=0;$index<$level;$index++){$char.="-----";}
                break;

            case ':':
                $post = " ";
                break;

            case "\t": case "\n": case "\r":
                $char = "";
                $ends_line_level = $new_line_level;
                $new_line_level = NULL;
                break;
        }
    } else if ( $char === '\\' ) {
        $in_escape = true;
    }
    if( $new_line_level !== NULL ) {
        $result .= "\n".str_repeat( "\t", $new_line_level );
    }
    $result .= $char.$post;
}

echo "RESULTS ARE: <br><br>$result";
return $result;

}

次に、関数prettyPrint($ your_json_string);を実行します。あなたのphpにインラインで印刷して楽しんでください。ミニマリストで、なんらかの理由で角括弧が気に入らない場合は、$ charの上位3つのスイッチケースで$char.="<br>";$char="<br>";に置き換えることで、角括弧を簡単に取り除くことができます。カルガリー市のGoogle Maps API呼び出しで取得できるものは次のとおりです

RESULTS ARE: 

{
- - - "results" : [
- - -- - - {
- - -- - -- - - "address_components" : [
- - -- - -- - -- - - {
- - -- - -- - -- - -- - - "long_name" : "Calgary"
- - -- - -- - -- - -- - - "short_name" : "Calgary"
- - -- - -- - -- - -- - - "types" : [
- - -- - -- - -- - -- - -- - - "locality"
- - -- - -- - -- - -- - -- - - "political" ]
- - -- - -- - -- - - }
- - -- - -- - -
- - -- - -- - -- - - {
- - -- - -- - -- - -- - - "long_name" : "Division No. 6"
- - -- - -- - -- - -- - - "short_name" : "Division No. 6"
- - -- - -- - -- - -- - - "types" : [
- - -- - -- - -- - -- - -- - - "administrative_area_level_2"
- - -- - -- - -- - -- - -- - - "political" ]
- - -- - -- - -- - - }
- - -- - -- - -
- - -- - -- - -- - - {
- - -- - -- - -- - -- - - "long_name" : "Alberta"
- - -- - -- - -- - -- - - "short_name" : "AB"
- - -- - -- - -- - -- - - "types" : [
- - -- - -- - -- - -- - -- - - "administrative_area_level_1"
- - -- - -- - -- - -- - -- - - "political" ]
- - -- - -- - -- - - }
- - -- - -- - -
- - -- - -- - -- - - {
- - -- - -- - -- - -- - - "long_name" : "Canada"
- - -- - -- - -- - -- - - "short_name" : "CA"
- - -- - -- - -- - -- - - "types" : [
- - -- - -- - -- - -- - -- - - "country"
- - -- - -- - -- - -- - -- - - "political" ]
- - -- - -- - -- - - }
- - -- - -- - - ]
- - -- - -
- - -- - -- - - "formatted_address" : "Calgary, AB, Canada"
- - -- - -- - - "geometry" : {
- - -- - -- - -- - - "bounds" : {
- - -- - -- - -- - -- - - "northeast" : {
- - -- - -- - -- - -- - -- - - "lat" : 51.18383
- - -- - -- - -- - -- - -- - - "lng" : -113.8769511 }
- - -- - -- - -- - -
- - -- - -- - -- - -- - - "southwest" : {
- - -- - -- - -- - -- - -- - - "lat" : 50.84240399999999
- - -- - -- - -- - -- - -- - - "lng" : -114.27136 }
- - -- - -- - -- - - }
- - -- - -- - -
- - -- - -- - -- - - "location" : {
- - -- - -- - -- - -- - - "lat" : 51.0486151
- - -- - -- - -- - -- - - "lng" : -114.0708459 }
- - -- - -- - -
- - -- - -- - -- - - "location_type" : "APPROXIMATE"
- - -- - -- - -- - - "viewport" : {
- - -- - -- - -- - -- - - "northeast" : {
- - -- - -- - -- - -- - -- - - "lat" : 51.18383
- - -- - -- - -- - -- - -- - - "lng" : -113.8769511 }
- - -- - -- - -- - -
- - -- - -- - -- - -- - - "southwest" : {
- - -- - -- - -- - -- - -- - - "lat" : 50.84240399999999
- - -- - -- - -- - -- - -- - - "lng" : -114.27136 }
- - -- - -- - -- - - }
- - -- - -- - - }
- - -- - -
- - -- - -- - - "place_id" : "ChIJ1T-EnwNwcVMROrZStrE7bSY"
- - -- - -- - - "types" : [
- - -- - -- - -- - - "locality"
- - -- - -- - -- - - "political" ]
- - -- - - }
- - - ]

- - - "status" : "OK" }

本当にありがとうございます。わずかな改善を加えると私が思うことの1つは、varを$ indent = "-----"に使用して、それを使用することです(コードのさまざまな場所で "
------

3

以下のようにできます。

$array = array(
   "a" => "apple",
   "b" => "banana",
   "c" => "catnip"
);

foreach ($array as $a_key => $a_val) {
   $json .= "\"{$a_key}\" : \"{$a_val}\",\n";
}

header('Content-Type: application/json');
echo "{\n"  .rtrim($json, ",\n") . "\n}";

上記はFacebookのようなものを出力します。

{
"a" : "apple",
"b" : "banana",
"c" : "catnip"
}

a_val配列またはオブジェクトの場合はどうなりますか?
Zach Rattner 2013年

1
質問でJsonを使用した例に回答しました。すぐに回答を更新します。
ジェイク

3

再帰的ソリューションの古典的なケース。これが私のものです:

class JsonFormatter {
    public static function prettyPrint(&$j, $indentor = "\t", $indent = "") {
        $inString = $escaped = false;
        $result = $indent;

        if(is_string($j)) {
            $bak = $j;
            $j = str_split(trim($j, '"'));
        }

        while(count($j)) {
            $c = array_shift($j);
            if(false !== strpos("{[,]}", $c)) {
                if($inString) {
                    $result .= $c;
                } else if($c == '{' || $c == '[') {
                    $result .= $c."\n";
                    $result .= self::prettyPrint($j, $indentor, $indentor.$indent);
                    $result .= $indent.array_shift($j);
                } else if($c == '}' || $c == ']') {
                    array_unshift($j, $c);
                    $result .= "\n";
                    return $result;
                } else {
                    $result .= $c."\n".$indent;
                } 
            } else {
                $result .= $c;
                $c == '"' && !$escaped && $inString = !$inString;
                $escaped = $c == '\\' ? !$escaped : false;
            }
        }

        $j = $bak;
        return $result;
    }
}

使用法:

php > require 'JsonFormatter.php';
php > $a = array('foo' => 1, 'bar' => 'This "is" bar', 'baz' => array('a' => 1, 'b' => 2, 'c' => '"3"'));
php > print_r($a);
Array
(
    [foo] => 1
    [bar] => This "is" bar
    [baz] => Array
        (
            [a] => 1
            [b] => 2
            [c] => "3"
        )

)
php > echo JsonFormatter::prettyPrint(json_encode($a));
{
    "foo":1,
    "bar":"This \"is\" bar",
    "baz":{
        "a":1,
        "b":2,
        "c":"\"3\""
    }
}

乾杯


3

このソリューションにより、「本当にきれいな」JSONが作成されます。OPが求めていたものとは異なりますが、JSONをよりよく視覚化できます。

/**
 * takes an object parameter and returns the pretty json format.
 * this is a space saving version that uses 2 spaces instead of the regular 4
 *
 * @param $in
 *
 * @return string
 */
function pretty_json ($in): string
{
  return preg_replace_callback('/^ +/m',
    function (array $matches): string
    {
      return str_repeat(' ', strlen($matches[0]) / 2);
    }, json_encode($in, JSON_PRETTY_PRINT | JSON_HEX_APOS)
  );
}

/**
 * takes a JSON string an adds colours to the keys/values
 * if the string is not JSON then it is returned unaltered.
 *
 * @param string $in
 *
 * @return string
 */

function markup_json (string $in): string
{
  $string  = 'green';
  $number  = 'darkorange';
  $null    = 'magenta';
  $key     = 'red';
  $pattern = '/("(\\\\u[a-zA-Z0-9]{4}|\\\\[^u]|[^\\\\"])*"(\s*:)?|\b(true|false|null)\b|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?)/';
  return preg_replace_callback($pattern,
      function (array $matches) use ($string, $number, $null, $key): string
      {
        $match  = $matches[0];
        $colour = $number;
        if (preg_match('/^"/', $match))
        {
          $colour = preg_match('/:$/', $match)
            ? $key
            : $string;
        }
        elseif ($match === 'null')
        {
          $colour = $null;
        }
        return "<span style='color:{$colour}'>{$match}</span>";
      }, str_replace(['<', '>', '&'], ['&lt;', '&gt;', '&amp;'], $in)
   ) ?? $in;
}

public function test_pretty_json_object ()
{
  $ob       = new \stdClass();
  $ob->test = 'unit-tester';
  $json     = pretty_json($ob);
  $expected = <<<JSON
{
  "test": "unit-tester"
}
JSON;
  $this->assertEquals($expected, $json);
}

public function test_pretty_json_str ()
{
  $ob   = 'unit-tester';
  $json = pretty_json($ob);
  $this->assertEquals("\"$ob\"", $json);
}

public function test_markup_json ()
{
  $json = <<<JSON
[{"name":"abc","id":123,"warnings":[],"errors":null},{"name":"abc"}]
JSON;
  $expected = <<<STR
[
  {
    <span style='color:red'>"name":</span> <span style='color:green'>"abc"</span>,
    <span style='color:red'>"id":</span> <span style='color:darkorange'>123</span>,
    <span style='color:red'>"warnings":</span> [],
    <span style='color:red'>"errors":</span> <span style='color:magenta'>null</span>
  },
  {
    <span style='color:red'>"name":</span> <span style='color:green'>"abc"</span>
  }
]
STR;

  $output = markup_json(pretty_json(json_decode($json)));
  $this->assertEquals($expected,$output);
}

}


2

のみを使用した場合$json_string = json_encode($data, JSON_PRETTY_PRINT);は、ブラウザに次のようなものが表示されます(質問のFacebookリンクを使用します:)): ここに画像の説明を入力してください

しかしJSONViewのようなChrome拡張機能を使用した場合(上記のPHPオプションなしでも)、次のように各単一のJSONオブジェクトを簡単に折りたたむ/折りたたむことができる、より読みやすいデバッグ可能なソリューションられます。 ここに画像の説明を入力してください


1

PHPのprint_r pretty print

PHPの例

function print_nice($elem,$max_level=10,$print_nice_stack=array()){
    if(is_array($elem) || is_object($elem)){
        if(in_array($elem,$print_nice_stack,true)){
            echo "<font color=red>RECURSION</font>";
            return;
        }
        $print_nice_stack[]=&$elem;
        if($max_level<1){
            echo "<font color=red>nivel maximo alcanzado</font>";
            return;
        }
        $max_level--;
        echo "<table border=1 cellspacing=0 cellpadding=3 width=100%>";
        if(is_array($elem)){
            echo '<tr><td colspan=2 style="background-color:#333333;"><strong><font color=white>ARRAY</font></strong></td></tr>';
        }else{
            echo '<tr><td colspan=2 style="background-color:#333333;"><strong>';
            echo '<font color=white>OBJECT Type: '.get_class($elem).'</font></strong></td></tr>';
        }
        $color=0;
        foreach($elem as $k => $v){
            if($max_level%2){
                $rgb=($color++%2)?"#888888":"#BBBBBB";
            }else{
                $rgb=($color++%2)?"#8888BB":"#BBBBFF";
            }
            echo '<tr><td valign="top" style="width:40px;background-color:'.$rgb.';">';
            echo '<strong>'.$k."</strong></td><td>";
            print_nice($v,$max_level,$print_nice_stack);
            echo "</td></tr>";
        }
        echo "</table>";
        return;
    }
    if($elem === null){
        echo "<font color=green>NULL</font>";
    }elseif($elem === 0){
        echo "0";
    }elseif($elem === true){
        echo "<font color=green>TRUE</font>";
    }elseif($elem === false){
        echo "<font color=green>FALSE</font>";
    }elseif($elem === ""){
        echo "<font color=green>EMPTY STRING</font>";
    }else{
        echo str_replace("\n","<strong><font color=red>*</font></strong><br>\n",$elem);
    }
}

1

1- json_encode($rows,JSON_PRETTY_PRINT);改行文字付きの事前定義されたデータを返します。これはコマンドライン入力には役立ちますが、ご存知のとおり、ブラウザー内では見た目がきれいではありません。ブラウザーは改行をソースとして受け入れます(したがって、ページのソースを表示すると、実際にはかなりのJSONが表示されます)が、ブラウザーでの出力のフォーマットには使用されません。ブラウザにはHTMLが必要です。

2-この機能githubを使用する

<?php
    /**
     * Formats a JSON string for pretty printing
     *
     * @param string $json The JSON to make pretty
     * @param bool $html Insert nonbreaking spaces and <br />s for tabs and linebreaks
     * @return string The prettified output
     * @author Jay Roberts
     */
    function _format_json($json, $html = false) {
        $tabcount = 0;
        $result = '';
        $inquote = false;
        $ignorenext = false;
        if ($html) {
            $tab = "&nbsp;&nbsp;&nbsp;&nbsp;";
            $newline = "<br/>";
        } else {
            $tab = "\t";
            $newline = "\n";
        }
        for($i = 0; $i < strlen($json); $i++) {
            $char = $json[$i];
            if ($ignorenext) {
                $result .= $char;
                $ignorenext = false;
            } else {
                switch($char) {
                    case '[':
                    case '{':
                        $tabcount++;
                        $result .= $char . $newline . str_repeat($tab, $tabcount);
                        break;
                    case ']':
                    case '}':
                        $tabcount--;
                        $result = trim($result) . $newline . str_repeat($tab, $tabcount) . $char;
                        break;
                    case ',':
                        $result .= $char . $newline . str_repeat($tab, $tabcount);
                        break;
                    case '"':
                        $inquote = !$inquote;
                        $result .= $char;
                        break;
                    case '\\':
                        if ($inquote) $ignorenext = true;
                        $result .= $char;
                        break;
                    default:
                        $result .= $char;
                }
            }
        }
        return $result;
    }

0

以下は私のために働いたものです:

test.phpの内容:

<html>
<body>
Testing JSON array output
  <pre>
  <?php
  $data = array('a'=>'apple', 'b'=>'banana', 'c'=>'catnip');
  // encode in json format 
  $data = json_encode($data);

  // json as single line
  echo "</br>Json as single line </br>";
  echo $data;
  // json as an array, formatted nicely
  echo "</br>Json as multiline array </br>";
  print_r(json_decode($data, true));
  ?>
  </pre>
</body>
</html>

出力:

Testing JSON array output


Json as single line 
{"a":"apple","b":"banana","c":"catnip"}
Json as multiline array 
Array
(
    [a] => apple
    [b] => banana
    [c] => catnip
)

また、htmlでの「pre」タグの使用にも注意してください。

誰かを助けることを願っています


2
これは質問の答えにはなりません。フォーマットされたJSONを出力するのではなく、変数をダンプしています。
Madbreaks、2015年

0

JSONデータをフォーマットする最良の方法は次のとおりです!

header('Content-type: application/json; charset=UTF-8');
echo json_encode($response, JSON_PRETTY_PRINT | JSON_UNESCAPED_UNICODE | JSON_UNESCAPED_SLASHES);

$ responseをJSONへの変換が必要なデータに置き換えます


0

PHPバージョン5.3以前を実行している場合は、以下を試すことができます。

$pretty_json = "<pre>".print_r(json_decode($json), true)."</pre>";

echo $pretty_json;

-4

MVCを使用している場合

あなたのコントローラーでこれをやってみてください

public function getLatestUsers() {
    header('Content-Type: application/json');
    echo $this->model->getLatestUsers(); // this returns json_encode($somedata, JSON_PRETTY_PRINT)
}

次に/ getLatestUsersを呼び出すと、かなりのJSON出力が得られます;)


エコーの後に私のコメントを参照してください。かなりprintendです
webmaster

1
MVCは一種のフレームワーク設計であり、JSONの出力とは関係ありません。
Maciej Paprocki

2013年の人々からの回答;)
ウェブマスター
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.