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