簡體   English   中英

在 CSV 中編寫字典列表

[英]Writing a list of dictionaries in CSV

下一個問題你有一個格式的字典列表

[{'a': 10, 'b': 11, 'c': 12, 'd': 13, 'e': 14}, 
 {'a': 20, 'b': 21, 'c': 22, 'd': 23, 'e': 24}, 
 {'a': 30, 'b': 31, 'c': 32, 'd': 33, 'e': 34}, 
 {'a': 40, 'b': 41, 'c': 42, 'd': 43, 'e': 44}]

你想移動到 CSV 文件,看起來像

"a","b","c","d","e"  
 10,11,12,13,14
 20,21,22,23,24
 30,31,32,33,34
 40,41,42,43,44

問題是當你開始代碼時:

def write_csv_from_list_dict(filename, table, fieldnames, separator, quote):
    table = []
    for dit in table:
        a_row = []
        for fieldname in fieldnames:
            a_row.append(dit[fieldname])
        table.append(a_row)
    file_handle = open(filename, 'wt', newline='')
    csv_write = csv.writer(file_handle,
                           delimiter=separator,
                           quotechar=quote,
                           quoting=csv.QUOTE_NONNUMERIC)
    csv_write.writerow(fieldnames)
    for row in table:
        csv_write.writerow(row)
    file_handler.close()

引發錯誤

(Exception: AttributeError) "'list' object has no attribute 'keys'" 
at line 148, in _dict_to_list wrong_fields = rowdict.keys() - self.fieldnames

為什么這么難說,明確地關閉一個文件,而不是一個字符串。

下面的代碼應該工作

data = [{'a': 10, 'b': 11, 'c': 12, 'd': 13, 'e': 14},
        {'a': 20, 'b': 21, 'c': 22, 'd': 23, 'e': 24},
        {'a': 30, 'b': 31, 'c': 32, 'd': 33, 'e': 34},
        {'a': 40, 'b': 41, 'c': 42, 'd': 43, 'e': 44}]
keys = data[0].keys()
with open('data.csv', 'w') as f:
    f.write(','.join(keys) + '\n')
    for entry in data:
        f.write(','.join([str(v) for v in entry.values()]) + '\n')

數據.csv

a,b,c,d,e
10,11,12,13,14
20,21,22,23,24
30,31,32,33,34
40,41,42,43,44

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM