добавление данных в список в файле json - PullRequest
1 голос
/ 10 марта 2019

Я делаю что-то для мониторинга сайта на наличие новых продуктов, поэтому я пытаюсь добавить все заголовки в файл json, который начинается с {"product_titles": []}, я пытаюсь понять, как добавить в пустые списки слова, содержащие название и размеры товара это мой код

import requests
import json

url = 'https://www.supremenewyork.com/mobile_stock.json'
headers = {
    'User-Agent': 'Mozilla/5.0 (iPhone; CPU iPhone OS 12_1_4 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/12.0 Mobile/15E148 Safari/604.1',
    'Accept': 'application/json',
    'Accept-Encoding': 'br, gzip, deflate',
    'Accept-Language': 'en-us'
}


req = requests.get(url, headers=headers)#

page = req.json()
categories = page['products_and_categories']
Sweatshirts = categories['Sweatshirts']


product_list = []
for sweater in Sweatshirts:
    product_name = sweater['name']
    product_colors = []
    product_sizes = []
    product_stock_levels = []
    #print(product_name)
    raw_product_info = requests.get('https://www.supremenewyork.com/shop/' + str(sweater['id']) + '.json', headers=headers)
    product_info = raw_product_info.json()
    styles = product_info['styles']
    for style in styles:
        colors = style['name']
        full_product_name = product_name + colors
        file = open
        product_colors.append(colors)
        for size in style['sizes']:
            sizes = {size['name'] : size['stock_level']}
            product_sizes.append(sizes)
            with open('supreme.json', 'r+') as supremef:
                data = json.load(supremef)
                dump = json.dump(data['product_titles'].append({full_product_name: sizes}), supremef)


последние несколько строк, в которых я пытаюсь добавить его в список в файле json, но он не добавляется в него

1 Ответ

1 голос
/ 10 марта 2019

Как указал @tmadam в комментариях, вот небольшое объяснение.

Вы ожидаете, что операция append вернет весь объект, который затем должен сохранить json.dump.

Этот пример показывает, что это не работает, так как append возвращает None.

>>> mydict = {"items": [1,2,3,4]}
>>> type(mydict["items"].append(5))
<class 'NoneType'>
>>> print(mydict)
{'items': [1, 2, 3, 4, 5]}
>>> 

См. Также этот вопрос для обсуждения этого поведения, я не могдля этого в документации по Python нет записи.

Ваш код, вероятно, должен выглядеть следующим образом:

data = json.load(supremef)
data['product_titles'].append({full_product_name: sizes})
dump = json.dump(data, supremef)

Немного не по теме:

Ваш file = open, вероятно, не делает то, что вы ожидаете.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...