有几个选项:
(1) 费力地将您的字段名称制作成一个身份映射字典(即不执行任何操作),以便csv.DictWriter可以将其转换回列表并将其传递给csv.writer实例。
(2) 文档提到了“底层writer
实例”…所以只需使用它(示例在末尾)。
dw.writer.writerow(dw.fieldnames)
(3) 避免使用csv.Dictwriter,而是使用csv.writer自己编写代码
写入数据:
w.writerow([d[k] for k in fieldnames])
或者
w.writerow([d.get(k, restval) for k in fieldnames])
我希望自己编写代码,而不是使用“extrasaction”功能;这样,您可以报告所有“extras”的键和值,而不仅仅是第一个额外的键。使用DictWriter的真正麻烦之处在于,如果您在构建每个字典时已经验证了键,则需要记住使用extrasaction ='ignore',否则它将慢慢(fieldnames是一个列表)重复检查。
wrong_fields = [k for k in rowdict if k not in self.fieldnames]
============
>>> f = open('csvtest.csv', 'wb')
>>> import csv
>>> fns = 'foo bar zot'.split()
>>> dw = csv.DictWriter(f, fns, restval='Huh?')
# dw.writefieldnames(fns) -- no such animal
>>> dw.writerow(fns) # no such luck, it can't imagine what to do with a list
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "C:\python26\lib\csv.py", line 144, in writerow
return self.writer.writerow(self._dict_to_list(rowdict))
File "C:\python26\lib\csv.py", line 141, in _dict_to_list
return [rowdict.get(key, self.restval) for key in self.fieldnames]
AttributeError: 'list' object has no attribute 'get'
>>> dir(dw)
['__doc__', '__init__', '__module__', '_dict_to_list', 'extrasaction', 'fieldnam
es', 'restval', 'writer', 'writerow', 'writerows']
# eureka
>>> dw.writer.writerow(dw.fieldnames)
>>> dw.writerow({'foo':'oof'})
>>> f.close()
>>> open('csvtest.csv', 'rb').read()
'foo,bar,zot\r\noof,Huh?,Huh?\r\n'
>>>
dw.writerow( dict((f,f) for f in dr.fieldnames) )
。 - FMcdw = csv.DictWriter(fou, delimiter='\t', fieldnames=dr.fieldnames)
添加字段。这样,如果您的字段发生更改,则无需调整dictWriter。 - Spencer Rathbun