python 文件读写时用open还是codecs.open
2016-12-29 11:03
288 查看
python读写文件估计大家都用open内置函数,或者file这个工厂函数,这两个的效果基本一样。
打开文件的方式一般为:f=open(file_name,access_mode = 'r',buffering = -1)。file_name就是文件的路径加文件名字,不加路径则文件会存放在python程序的路径下,
access_mode就是操作文件的模式,主要有r,w,rb,wb等,细节网上一大堆,buffering
= -1是用于指示访问文件所采用的缓存方式。0表示不缓存;1表示只缓存一行,n代表缓存n行。如果不提供或为负数,则代表使用系统默认的缓存机制。
打开以后就是写和读的操作。但是用open方法打开会有一些问题。open打开文件只能写入str类型,不管字符串是什么编码方式。例如
>>> fr = open('test.txt','a')
>>> line1 = "我爱祖国"
>>> fr.write(line1)
这样是完全可以的。但是有时候我们爬虫或者其他方式得到一些数据写入文件时会有编码不统一的问题,所以就一般都统一转换为unicode。此时写入open方式打开的文件就有问题了。例如
>>> line2 = u'我爱祖国'
>>> fr.write(line2)
Traceback (most recent call last):
File "<pyshell#4>", line 1, in <module>
fr.write(line2)
UnicodeEncodeError: 'ascii' codec can't encode characters in position 0-11: ordinal not in range(128)
>>>
怎么办,我们可以将上面的line2编码成str类型,但是太麻烦。我们要把得到的东西先decode为unicode再encode为str。。。
input文件(gbk, utf-8...) ----decode-----> unicode -------encode------> output文件(gbk, utf-8...)
代替这繁琐的操作就是codecs.open,例如
>>> import codecs
>>> fw = codecs.open('test1.txt','a','utf-8')
>>> fw.write(line2)
>>>
不会报错,说明写入成功。这种方法可以指定一个编码打开文件,使用这个方法打开的文件读取返回的将是unicode。写入时,如果参数
是unicode,则使用open()时指定的编码进行编码后写入;如果是str,则先根据源代码文件声明的字符编码,解码成unicode后再进行前述 操作。相对内置的open()来说,这个方法比较不容易在编码上出现问题。
总结一下:文件读尽量用第二种方法,一般不会出现编码的问题。至于用第二种方法有什么缺点,我没有研究过。。
原文链接:http://www.cnblogs.com/buptldf/p/4805879.html
相关文章推荐
- python 文件读写时用open还是codecs.open
- python 文件读写时用open还是codecs.open
- python 文件读写时用open还是codecs.open
- python open文件 读写模式说明
- open()文件对象的seek、tell方法详解 分类: python基础学习 open()文件读写 python Module 2013-09-05 09:40 450人阅读 评论(0) 收藏
- Python 文件操作中的读写模式:open(path, '-模式-',encoding='UTF-8')
- Python open读写文件实现脚本
- Python文件操作,open读写文件,追加文本内容
- 【python学习02】- open读写文件
- python 读写文件函数open()用法
- 【python】Python open读写文件
- Python文件操作,open读写文件,追加文本内容(转)
- 文件操作注意事项 分类: python 小练习 python基础学习 open()文件读写 2013-12-03 11:05 532人阅读 评论(0) 收藏
- Python 读写文件(open、pickle)
- Python open读写文件实现脚本
- Python open读写文件实现脚本
- Python open读写文件实现脚本
- Python open读写文件实现脚本
- python-open()-文件读写
- python文件读写(open参数,文件缓冲,内存映射,临时文件)