簡體   English   中英

python dicts轉換成CSV

[英]python dicts into CSV

如何將類似鍵的python字典寫入csv,其中鍵成為標頭字段。 例如:

dict1 =
  {
   key1: value1,
   key2: value2,
   key3: value3,
  }

dict2 =
  {
   key1: value4,
   key2: value5,
   key3: value6,
  }

  key1,key2,key3
  value1,value2,value3
  value4,value5,value6

如果您還喜歡兩個命令,請嘗試以下操作:

import csv

dict1 ={
   "key1": "value1",
   "key2": "value2",
   "key3": "value3"}

dict2 ={
   "key1": "value4",
   "key2": "value5",
   "key3": "value6"}

dict3 ={
   "key1": "value7",
   "key2": "value8",
   "key3": "value9"}

data = [dict1,dict2,dict3]

dict_writer = csv.DictWriter(file('my.csv','wb'),fieldnames=dict1.keys())
dict_writer.writeheader()
dict_writer.writerows(data)

你可以這樣嘗試嗎:

#!/usr/bin/python

import csv

dict1 = {
   'key1': 'value1',
   'key2': 'value2',
   'key3': 'value3',
  }

with open('csv_test.csv', 'wb') as fh:
    w = csv.DictWriter(fh, dict1.keys())
    w.writeheader()
    w.writerow(dict1)

如果詞典不同,請嘗試以下操作:

import csv

dict1 = {1:'a',2:'b',3:'c'}
dict2 = {1:'aa',2:'bb',3:'cc'}
dict2[4] = 'dd'

keyset = set(dict1.keys() + dict2.keys())

with open('output.csv','w') as o:
    f = csv.writer(o)
    #write keys
    keylist = list(keyset)
    f.writerow(keylist)
    rowlist = []
    rowlist2 = []
    for i in keylist:   
        if i in dict1.keys():
            rowlist.append(dict1[i])
        else:
            rowlist.append('None')
        if i in dict2.keys():
            rowlist2.append(dict2[i])
        else:
            rowlist2.append('None')
    f.writerow(rowlist)
    f.writerow(rowlist2)

暫無
暫無

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

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