检查JSON字典是否为空并存储在列表中

时间:2016-04-26 10:06:58

标签: python json loops instagram-api

我有一个Instagram API,我加载到JSON中。响应正常,我甚至可以从收到的数据中获取id。然后我将它保存在python列表中,并使用openpyxl将其放在Excel表格中。

这是捕获。在加载值时,如果在删除的Instagram帐户中没有来自API的响应,那么JSON将为空,我想存储" ACC已删除"在列表中。

(注意: - 我也提到了类似的问题,但没有得到我的答案。)

以下是代码:

for r in range(1,51):
    var=r,test.cell(row=r,column=1).value
    xy=var[1]
    myopener=Myopener()
    url=myopener.open('https://api.instagram.com/v1/users/search?q='+xy+'&count=1&access_token=641567093.1fb234f.a0ffbe574e844e1c818145097050cf33')

    **beta=json.load(url)
    for item in beta['data']:
        list.append(item['id'])** //*HERE I WANT THE CHANGE*


    for j in range(len(list)):
        for row in sheet.iter_rows(min_row=j+1, max_row=j+1):
            for cell in row:
                cell.value=list[j]
                wb.save('sample.xlsx')

json响应是这样的:

{
"meta":  {
"code": 200
},
"data":  [
 {
  "username": "rawhawk_sk",
  "profile_picture": "https://scontent.cdninstagram.com/t51.2885-19/s150x150/12724928_109384759877664_1105313598_a.jpg",
  "id": "670907103",
  "full_name": "shwan mcswan"
}
]
}

如果json响应为空,如下所示,如何存储" ACC已删除"在列表中?

{
"meta":  {
"code": 200
},
"data":  []
} 

1 个答案:

答案 0 :(得分:0)

您可以检查脚本中的数据是否为空,如果是,请添加新条目“ACC已删除”'到列表。

import json

jsons = []
jsons.append("""{
"meta":  {
"code": 200
},
"data":  [
 {
  "username": "rawhawk_sk",
  "profile_picture": "https://scontent.cdninstagram.com/t51.2885-19/s150x150/12724928_109384759877664_1105313598_a.jpg",
  "id": "670907103",
  "full_name": "shwan mcswan"
}
]
}
""")

jsons.append("""{
"meta":  {
"code": 200
},
"data":  []
} """)

output_list = []

for txt in jsons:
    beta = json.loads(txt)
    if beta.get('data'):
        for item in beta['data']:
            output_list.append(item['id'])
    else:
        output_list.append('ACC deleted')

print(output_list)