Python:默认的dict键,以避免KeyError

时间:2014-07-17 21:41:33

标签: python json csv dictionary keyerror

python,新手开发人员,第一次来电者

相当新

我正在调用一些JSON并将相关数据解析为csv。我无法弄清楚如何使用默认密钥填充中间json Dict文件,因为许多都是未填充的。结果是KeyError,因为我试图将内容解析为csv。会喜欢任何建议!

感谢。

更新:谢谢大家!我现在收到了一个' NoneType' (制造商)的错误:

import urllib2, json, csv, sys, os, codecs, re

from collections import defaultdict

output = 'bb.csv'

csv_writer = csv.writer(open(output, 'w'))

header = ['sku', 'name', 'description', 'image', 'manufacturer', 'upc', 'department', 'class', 'subclass']

csv_writer.writerow(header)

i=1

while i<101:
    print i

    bb_url = urllib2.Request("http://api.remix.bestbuy.com/v1/products(sku=*)?show=sku,name,description,image,manufacturer,upc,department,class,subclass&format=json&sort=sku.asc&page=" + str(i) + "&pageSize=100&apiKey=*****************")
    bb_json = json.load(urllib2.urlopen(bb_url))

    print bb_json

    for product in bb_json['products']:
        row = []

        row.append(product['sku'])
        if product['name']:
            row.append(str((product['name']).encode('utf-8')))
        else:
            row.append("")
        row.append(str(product.get('description',"")))
        row.append(str(product['image'])+ " ")
        if product['name']:
            row.append(str(product.get('manufacturer',"").encode('utf-8')))
        else:
            row.append("")
        row.append(str(product.get('upc','').encode('utf-8')))
        row.append(str((product['department']).encode('utf-8')))
        row.append(str((product['class']).encode('utf-8')))
        row.append(str((product['subclass']).encode('utf-8')))

        csv_writer.writerow(row)

    i = i+1

4 个答案:

答案 0 :(得分:56)

您可以使用your_dict.get(key, "default value")代替直接引用密钥。

答案 1 :(得分:8)

不要使用“默认”参数名称。例如,如果我们想要1.0作为默认值,

rank = dict.get(key, 1.0)

了解更多详情: TypeError: get() takes no keyword arguments

答案 2 :(得分:7)

如果您无法定义默认值并想要做其他事情(或者只是忽略该条目):

if key in dict:
    rank = dict[key]
else:
    # do something or just skip the else block entirely

答案 3 :(得分:2)

您可以使用以下语法:product.get("your field", "default value")