python寫csv文件
Python提供了內(nèi)置模塊讀寫csv文件,這里我只用到了寫,讀這里就不做介紹了,也不難,主要是解決亂碼問題。
defsave2csv(file_name=None,header=None,data=None):
"""
保存成CSV格式文件,方便Excel直接打開
:paramfile_name:保存的文件名
:paramheader:表頭,每一列的名字
:paramdata:具體填充數(shù)據(jù)
:return:
"""
iffile_nameisNoneorisinstance(file_name,basestring)isFalse:
raiseException('保存CSV文件名不能為空,并且必須為字符串類型')
iffile_name.endswith('.csv')isFalse:
file_name+='.csv'
file_obj=open(file_name,'wb')
file_obj.write(codecs.BOM_UTF8)#防止亂碼
writer=csv.writer(file_obj)
ifdataisNoneorisinstance(data,(tuple,list))isFalse:
raiseException('保存CSV文件失敗,數(shù)據(jù)為空或者不是數(shù)據(jù)類型')
ifheaderisnotNoneandisinstance(header,(tuple,list))isTrue:
writer.writerow(header)
forrowindata:
writer.writerow(row)
注意:有三句話就是為了防止亂碼的
file_obj=open(file_name,'wb')
file_obj.write(codecs.BOM_UTF8)#防止亂碼
writer=csv.writer(file_obj)
在文件頭部寫入codecs.BOM_UTF8就能防止亂碼了,文件都是utf-8編碼格式的。
以上內(nèi)容為大家介紹了python3寫入csv亂碼怎么解決,希望對(duì)大家有所幫助,如果想要了解更多Python相關(guān)知識(shí),請(qǐng)關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。