json_decode (), когда есть несколько результатов

1

Я пытаюсь понять, как я могу получить SKU (и дополнительно ID) от результатов json. Я могу сделать это, когда есть только один набор значений, называемых SKU, но я потратил часы, пытаясь понять, как это сделать, когда их несколько.

Ниже приведен пример того, что возвращает мой json

{
    "variants": [
        {
            "id": 6852445,
            "name": "Ikan VK7i 7\" LCD Monitor for Sony L with sun hood",
            "sku": "VK7i-S-SHX7",
        },
        {
            "id": 6852388,
            "name": "ikan Flyweight DSLR",
            "sku": "ELE-FLWDSLR",
        },
        {
            "id": 6838367,
            "name": "Atomos Sun Hood for Ninja/Ninja-2 including Double Adapter",
            "sku": "AO-ATOMSUN001",
        },
                ]
}

У меня есть этот код (я новичок). То, что я пытаюсь сделать, это сделать sku и идентификатор обеих переменных, но я просто ударяю кирпичную стену. В настоящее время я получаю

Предупреждение: неверный аргумент, предоставленный foreach() в /home/pearingc/public_html/returns/test2.php в строке 15

<?php

$context = stream_context_create(array(
    'http' => array(
        'header'  => "Authorization: Bearer *my token details* ")
    )
);

$url = "http://api.tradegecko.com/variants/";
$data = file_get_contents($url, false, $context);

$json = json_decode($data, true);

$product = $json{'variant'}->{'sku'};
foreach ($product['sku'] as $sku) {
print $sku;
}

?>

Изменение: это то, что var_dump ($ json); дает мне

object(stdClass)#1 (2) { ["variants"]=> array(100) { [0]=> object(stdClass)#2 (42) { ["id"]=> int(6852445) ["created_at"]=> string(24) "2015-05-20T10:09:09.629Z" ["updated_at"]=> string(24) "2015-05-20T10:10:40.351Z" ["product_id"]=> int(1991122) ["default_ledger_account_id"]=> NULL ["buy_price"]=> string(5) "404.0" ["committed_stock"]=> string(1) "0" ["incoming_stock"]=> string(1) "0" ["composite"]=> bool(true) ["description"]=> NULL ["is_online"]=> bool(false) ["keep_selling"]=> bool(false) ["last_cost_price"]=> NULL ["manage_stock"]=> bool(true) ["max_online"]=> NULL ["moving_average_cost"]=> NULL ["name"]=> string(49) "Ikan VK7i 7" LCD Monitor for Sony L with sun hood" ["online_ordering"]=> bool(false) ["opt1"]=> NULL ["opt2"]=> NULL ["opt3"]=> NULL ["position"]=> int(6) ["product_name"]=> string(33) "ikan 7" HDMI Monitor W/ IPS Panel" ["product_status"]=> string(6) "active" ["product_type"]=> string(8) "Monitors" ["retail_price"]=> NULL ["sellable"]=> bool(true) ["sku"]=> string(11) "VK7i-S-SHX7" ["status"]=> string(6) "active" ["stock_on_hand"]=> string(1) "0" ["supplier_code"]=> NULL ["taxable"]=> bool(true) ["upc"]=> NULL ["weight"]=> NULL ["wholesale_price"]=> NULL ["image_ids"]=> array(0) { } ["variant_prices"]=> array(1) { [0]=> object(stdClass)#3 (2) { ["price_list_id"]=> string(3) "buy" ["value"]=> string(5) "404.0" } } ["locations"]=> array(1) { [0]=> object(stdClass)#4 (6) { ["location_id"]=> int(16377) ["stock_on_hand"]=> string(1) "0" ["committed"]=> string(1) "0" ["incoming"]=> NULL ["bin_location"]=> NULL ["reorder_point"]=> NULL } } ["prices"]=> object(stdClass)#5 (1) { ["buy"]=> string(5) "404.0" } ["stock_levels"]=> object(stdClass)#6 (1) { ["16377"]=> string(3) "0.0" } ["committed_stock_levels"]=> object(stdClass)#7 (1) { ["16377"]=> string(3) "0.0" } ["incoming_stock_levels"]=> object(stdClass)#8 (0) { } } 
  • 0
    Я бы посоветовал вам добавить var_dump($json) в ваш код, чтобы увидеть, какая у вас структура данных. Подсказка: не содержит объектов. Кроме того, добавьте error_reporting(E_ALL) в начале вашего скрипта, чтобы включить уведомления. Они часто указывают вам на орфографические и логические ошибки.
  • 0
    последнее свойство объекта / массива не должно иметь запятой после него, поэтому json для начала недопустим. После того, как вы json_decode вы должны проверить json_last_error() чтобы увидеть, если была проблема.
Показать ещё 2 комментария
Теги:
decode

2 ответа

3
Лучший ответ

Я думаю, что вы нарушили JSON. Примечание. Я удалил запятые после sku. Попробуй это:

$data = '{
"variants": [
    {
        "id": 6852445,
        "name": "Ikan VK7i 7\" LCD Monitor for Sony L with sun hood",
        "sku": "VK7i-S-SHX7"
    },
    {
        "id": 6852388,
        "name": "ikan Flyweight DSLR",
        "sku": "ELE-FLWDSLR"
    },
    {
        "id": 6838367,
        "name": "Atomos Sun Hood for Ninja/Ninja-2 including Double Adapter",
        "sku": "AO-ATOMSUN001"
    }
]
}';

И после этого:

$json = json_decode($data);
foreach ($json->variants as $row) {
    print $row->sku;
}
  • 0
    Да. Ты прав. Спасибо - обновляю ответ.
  • 0
    Спасибо вам большое! Я потратил часы на это !!!!
Показать ещё 2 комментария
0
<?php

$json = '{
    "variants": [
        {
            "id": 6852445,
            "name": "Ikan VK7i 7\" LCD Monitor for Sony L with sun hood",
            "sku": "VK7i-S-SHX7"
        },
        {
            "id": 6852388,
            "name": "ikan Flyweight DSLR",
            "sku": "ELE-FLWDSLR"
        },
        {
            "id": 6838367,
            "name": "Atomos Sun Hood for Ninja/Ninja-2 including Double Adapter",
            "sku": "AO-ATOMSUN001"
        }
    ]
}';

foreach(json_decode($json,true)['variants'] as $item) {
  echo $item['sku'] . "<br />";
}
?>

Сжала его немного.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню