python3写入csv乱码怎么解决
python写csv文件
Python提供了内置模块读写csv文件,这里我只用到了写,读这里就不做介绍了,也不难,主要是解决乱码问题。
defsave2csv(file_name=None,header=None,data=None):
"""
保存成CSV格式文件,方便Excel直接打开
:paramfile_name:保存的文件名
:paramheader:表头,每一列的名字
:paramdata:具体填充数据
: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文件失败,数据为空或者不是数据类型')
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编码格式的。
以上内容为大家介绍了python3写入csv乱码怎么解决,希望对大家有所帮助,如果想要了解更多Python相关知识,请关注IT培训机构:千锋教育。

猜你喜欢LIKE
相关推荐HOT
更多>>
python函数中使用for循环
python函数中使用for循环1、在for循环中使用函数需要更长的执行时间,因为每次迭代都会调用该函数。2、如果for循环是在函数内部实现的,那么该...详情>>
2023-11-14 13:53:34
python3.1版本的特性有哪些
python3.1中的特性有哪些1、千位数格式化,可以在使用字符串格式化函数时直接完成。在格式化大数时,通常是每三位数放置逗号,使数字更易读(例...详情>>
2023-11-14 13:18:27
python__new__()和__init__()有什么区别?
在python中,__new__()不是一定要有,只有继承自object的类才有,该方法可以return父类(通过super(当前类名,cls).__new__())出来的实例,或者直...详情>>
2023-11-14 12:38:55
pythonwheel是什么
python的第一个主流打包格式是.egg文件,现在大家庭中又有了一个叫做Wheel(*.whl)的新成员。wheel“被设计成包含PEP376兼容安装(一种非常接近于...详情>>
2023-11-14 11:30:39热门推荐
pythonSymPy求极值
沸python归并排序和快速排序比较
热pythonpartition如何分割字符串
热pythonif-elif-else语句的使用注意
新python函数中使用for循环
python3.1版本的特性有哪些
python__new__()和__init__()有什么区别?
python作为小白该如何抉择python编辑器?
pythonwheel是什么
python如何定义一个函数
pythonpython是什么类型的语言
python怎么传参数
pythonshell是什么
python如何查看对象属性
技术干货






