Як конвертувати рядок JSON в масив


123

Я хочу зробити таке:

  1. прийняття JSON як введення з області тексту в php
  2. використовуйте цей вхід і конвертуйте його в JSON і передайте його в php curl для надсилання запиту.

це я потрапляю на php від отримання api цього рядка json, я хочу перейти до json, але він не перетворюється на масив

echo $str='{
        action : "create",
        record: {
            type: "n$product",
            fields: {
                n$name: "Bread",
                n$price: 2.11
            },
            namespaces: { "my.demo": "n" }
        }
    }';
    $json = json_decode($str, true);

наведений вище код не повертає мені масив.


1
Чи потрібно перетворити рядок json в масив АБО ви хочете підробити URL з цих даних? Яке саме питання?
Яніс Вейнбергс

then it is not givingНе даючи чого? Ви берете рядок формату JSON з textarea і перетворюєте його в JSON ???
PeeHaa

1
якщо ви робите вищевказаний json у моєму запитанні json_decode (, правда), чи він відновлює масив
XMen

@Pekka Перевірте ще раз мій питання.
XMen

3
це недійсна проблема json.
XMen

Відповіді:


187

Якщо ви передасте JSON у своєму посту json_decode, він не вдасться. Дійсні рядки JSON цитують ключі:

json_decode('{foo:"bar"}');         // this fails
json_decode('{"foo":"bar"}', true); // returns array("foo" => "bar")
json_decode('{"foo":"bar"}');       // returns an object, not an array.

якщо ви робите вищевказаний json у моєму запитанні json_decode (, правда), чи він відновлює масив
XMen

@RahulMehta Якщо ви використовуєте вбудований PHP, json_decode()він повернеться, NULLякщо ваш JSON недійсний (наприклад, немає цитованих ключів). Ось що говорить документація, і ось що повертається моя установка PHP 5.2. Чи використовуєте ви вбудовану функцію, відмінну від офіційної json_decode()? Що var_dump(json_decode($str, true));повертає?
RickN

після json_encoding я хотів би прочитати кожен окремий об'єкт json, наприклад {foo: "bar"} як об'єкт у масиві. як я можу створити масив із даних json_encoded, щоб прочитати кожен об’єкт json? @RikkusRukkus
Manny265

@ Manny265 це звучить як щось, що заслуговує на власне запитання з (1) деяким зразковим кодом, (2) тим, що ви намагалися до цього часу, і (3) очікуваним результатом, а не цим розділом коментарів.
RickN

96

Спробуйте це:

$data = json_decode($your_json_string, TRUE);

другий параметр перетворить декодовану рядок json в асоціативний масив.


30

Якщо ви отримуєте рядок JSON з форми , використовуючи $_REQUEST, $_GETабо $_POSTвам потрібно буде використовувати функцію html_entity_decode(). Я не усвідомлював цього, поки не зробив var_dumpте, що було у запиті, порівняно з тим, що я скопіював у та echoзаяву, і помітив, що рядок запиту значно більший.

Правильний шлях:

$jsonText = $_REQUEST['myJSON'];
$decodedText = html_entity_decode($jsonText);
$myArray = json_decode($decodedText, true);

З помилками:

$jsonText = $_REQUEST['myJSON'];
$myArray = json_decode($jsonText, true);
echo json_last_error(); //Returns 4 - Syntax error;

2
Ідеально, це працює. коли я отримую дані від $ _POST, функція json_last_error () була = JSON_ERROR_SYNTAX. але все завжди було добре. Це була помилка декодування, а не помилка кодування, як ascii або utf8. СПАСИБО

11

Використовуйте json_decode($json_string, TRUE)функцію для перетворення об'єкта JSON в масив.

Приклад:

$json_string   = '{"a":1,"b":2,"c":3,"d":4,"e":5}';

$my_array_data = json_decode($json_string, TRUE);

ПРИМІТКА: Другий параметр перетворить декодовану рядок JSON в асоціативний масив.

============

Вихід:

var_dump($my_array_data);

array(5) {

    ["a"] => int(1)
    ["b"] => int(2)
    ["c"] => int(3)
    ["d"] => int(4)
    ["e"] => int(5)
}

6

Якщо ви отримуєте рядок json з URL-адреси file_get_contents, виконайте дії:

$url = "http://localhost/rest/users";  //The url from where you are getting the contents
$response = (file_get_contents($url)); //Converting in json string
 $n = strpos($response, "[");
$response = substr_replace($response,"",0,$n+1);
$response = substr_replace($response, "" , -1,1);
print_r(json_decode($response,true));

6

ваш рядок має бути у такому форматі:

$str = '{"action": "create","record": {"type": "n$product","fields": {"n$name": "Bread","n$price": 2.11},"namespaces": { "my.demo": "n" }}}';
$array = json_decode($str, true);

echo "<pre>";
print_r($array);

Вихід:

Array
 (
    [action] => create
    [record] => Array
        (
            [type] => n$product
            [fields] => Array
                (
                    [n$name] => Bread
                    [n$price] => 2.11
                )

            [namespaces] => Array
                (
                    [my.demo] => n
                )

        )

)

2

Ви можете конвертувати json Object у масив та рядок.

$data='{"resultList":[{"id":"1839","displayName":"Analytics","subLine":""},{"id":"1015","displayName":"Automation","subLine":""},{"id":"1084","displayName":"Aviation","subLine":""},{"id":"554","displayName":"Apparel","subLine":""},{"id":"875","displayName":"Aerospace","subLine":""},{"id":"1990","displayName":"Account Reconciliation","subLine":""},{"id":"3657","displayName":"Android","subLine":""},{"id":"1262","displayName":"Apache","subLine":""},{"id":"1440","displayName":"Acting","subLine":""},{"id":"710","displayName":"Aircraft","subLine":""},{"id":"12187","displayName":"AAC","subLine":""}, {"id":"20365","displayName":"AAT","subLine":""}, {"id":"7849","displayName":"AAP","subLine":""}, {"id":"20511","displayName":"AACR2","subLine":""}, {"id":"28585","displayName":"AASHTO","subLine":""}, {"id":"45191","displayName":"AAMS","subLine":""}]}';

$b=json_decode($data);

$i=0;
while($b->{'resultList'}[$i])
{
    print_r($b->{'resultList'}[$i]->{'displayName'});
    echo "<br />";
    $i++;
}

1

Якщо вам коли-небудь потрібно конвертувати файл або структури JSON в масиви стилів PHP, з усіма рівнями вкладення, ви можете використовувати цю функцію. По-перше, ви повинні json_decode ($ yourJSONdata), а потім передати його цій функції. Він виведе у вікно вашого браузера (або консоль) правильні масиви, що стилюються PHP.

https://github.com/mobsted/jsontophparray


1
<?php
$str='{
    "action" : "create",
    "record" : {
                "type": "$product",
                "fields": {
                           "name": "Bread",
                           "price": "2.11"
                           },
                "namespaces": { "my.demo": "n" }
                }
    }';
echo $str;
echo "<br>";
$jsonstr = json_decode($str, true);
print_r($jsonstr);

?>

Я думаю, що це повинно працювати, його клавіші мають бути також у подвійних лапках, якщо вони не є цифрами.


1

це моє рішення: json string $columns_validation = string(1736) "[{"colId":"N_ni","hide":true,"aggFunc":null,"width":136,"pivotIndex":null,"pinned":null,"rowGroupIndex":null},{"colId":"J_2_fait","hide":true,"aggFunc":null,"width":67,"pivotIndex":null,"pinned":null,"rowGroupIndex":null}]"

тому я використовую json_decode двічі так:

$js_column_validation = json_decode($columns_validation);
$js_column_validation = json_decode($js_column_validation); 

var_dump($js_column_validation);

і результат:

 array(15) { [0]=> object(stdClass)#23 (7) { ["colId"]=> string(4) "N_ni" ["hide"]=> bool(true) ["aggFunc"]=> NULL ["width"]=> int(136) ["pivotIndex"]=> NULL ["pinned"]=> NULL ["rowGroupIndex"]=> NULL } [1]=> object(stdClass)#2130 (7) { ["colId"]=> string(8) "J_2_fait" ["hide"]=> bool(true) ["aggFunc"]=> NULL ["width"]=> int(67) ["pivotIndex"]=> NULL ["pinned"]=> NULL ["rowGroupIndex"]=> NULL }

Thanksz bro ... Ви врятували мені день
Nuwan Withanage

1

Переконайтеся, що рядок у такому форматі JSON, що є приблизно таким:

{"result":"success","testid":"1"} (with " ") .

Якщо ні, то ви можете додати "responsetype => json"до запиту параметри.

Потім використовуйте json_decode($response,true)для перетворення його в масив.


1
Ласкаво просимо до StackOverflow :-) Громада завжди раді за нових членів, які хочуть внести свій внесок у цю справу, і цінує ваше ставлення. На жаль, інший учасник вважає, що ваша відповідь заслуговує на голосування. Це може бути, тому що саме запитання було задано близько семи років тому і на нього вже відповіли кілька разів. Крім того, responseTypeвластивість використовується для визначення типу даних у відповіді на запит. Однак проблема полягає в тому, що орган запиту містить дані, які не відповідають правильності від самого себе. Отже, ваша відповідь не відповідає заданому контексту.
Філіп Маурер

1

Ви можете змінити рядок на JSON наступним чином, а також можете обрізати, закреслити рядок, якщо потрібно,

$str     = '[{"id":1, "value":"Comfort Stretch"}]';
//here is JSON object
$filters = json_decode($str);

foreach($filters as $obj){
   $filter_id[] = $obj->id;
}

//here is your array from that JSON
$filter_id;

0

Використовуйте цей конвертор, він зовсім не виходить з ладу: Services_Json

// create a new instance of Services_JSON
$json = new Services_JSON();

// convert a complexe value to JSON notation, and send it to the browser
$value = array('foo', 'bar', array(1, 2, 'baz'), array(3, array(4)));
$output = $json->encode($value);
print($output);
// prints: ["foo","bar",[1,2,"baz"],[3,[4]]]

// accept incoming POST data, assumed to be in JSON notation
$input = file_get_contents('php://input', 1000000);
$value = $json->decode($input);

// if you want to convert json to php arrays:
$json = new Services_JSON(SERVICES_JSON_LOOSE_TYPE);

-2
$data = json_encode($result, true);

echo $data;

2
Хоча цей код може відповісти на питання, надаючи додатковий контекст стосовно того, чому та / або як цей код відповідає на питання, покращує його довгострокове значення.
rollstuhlfahrer
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.