Python文件读写详解及配置文件的字符编码
文件读写操纵在各类编程语言中都是较量重要的部门,也是很常用的部门,本日就来具体说一下python对文件的读写操纵,以及需要留意的点。
一. python打开文件
代码如下:
f = open("d:\test.txt", "w")
说明:
第一个参数是文件名称,包罗路径;
第二个参数是打开的模式mode
‘r’:只读(缺省。假如文件不存在,则抛堕落误)
‘w’:只写(假如文件不存在,则自动建设文件)
‘a’:附加到文件末端
‘r+’:读写
假如需要以二进制方法打开文件,需要在mode后头加上字符”b”,好比”rb””wb”等
二、python读取文件内容f.read([size])
参数size暗示读取的数量,可以省略。假如省略size参数,则暗示读取文件所有内容。
f.readline()读取文件一行的内容 f.readlines()读取所有的行到数组内里[line1,line2,…lineN]。
f = open('./pythontab.txt', 'r') content = f.read() print content
在制止将所有文件内容加载到内存中,这种要领经常利用,便于提高效率。
三、python写入文件f.write(string)
将一个字符串写入文件
f = open('./pythontab.txt', 'r+') f.write('Hello, Pythontab.com') f.close()
留意: 假如写入竣事,可以在字符串后头加上”\n”来暗示换行,最后必需用f.close()封锁文件。不然大概会呈现异常,出格是在高并发的环境下。
四、文件中的内容定位
f.read()读取之后,文件指针达到文件的末端,假如再来一次f.read()将会发明读取的是空内容,假如想再次读取全部内容,必需将定位指针移动到文件开始:
f.seek(0)
这个函数的名目如下(单元是bytes):f.seek(offset, from_what) from_what暗示开始读取的位置,offset暗示从from_what再移动必然量的间隔,好比f.seek(10, 3)暗示定位到第三个字符并再后移10个字符。
from_what值为0时暗示文件的开始,它也可以省略,缺省是0即文件开头。下面给出一个完整的例子:
f = open('./pythontab.txt', 'r+') f.write('Hello, Pythontab.com') f.seek(5) # 定位到第6个byte f.read(1) f.seek (-3, 2) #定位到第2个字符并再向前移动3个字符 f.read(1)
五、封锁文件
封锁文件释放资源文件操纵完毕,必然要记得封锁文件f.close(),可以释放资源供其他措施使只是ASCII可能gbk编码名目标的文件读写,较量简朴,读写如下:
# coding=gbk f = open('./pythontab.txt','r') # r 指示文件打开模式,即只读 s1 = f.read() s2 = f.readline() s3 = f.readlines() #读出所有内容 f.close() f = open('./pythontab.txt','w') # w 写文件 11 f.write(s1) 12 f.writelines(s2) # 没有writeline 13 f.close()
六. f.writelines不会输出换行符
python unicode文件读写:
# coding=gbk import codecs f = codecs.open('./pythontab.txt','a','utf-8') f.write(u'中文') s = '中文' f.write(s.decode('gbk')) f.close() f = codecs.open('./pythontab.txt','r','utf-8') s = f.readlines() f.close() for line in s: print line.encode('gbk')
七. python代码文件的编码
py文件默认是ASCII编码,中文在显示时会做一个ASCII到系统默认编码的转换,这时就会堕落:SyntaxError: Non-ASCII character。需要在代码文件的第一行或第二行添加编码指示:
# coding=utf-8 ##以utf-8编码储存中文字符
print ‘中文’像上面那样直接输入的字符串是凭据代码文件的编码来处理惩罚的,假如用unicode编码,有以下2种方法:
s1 = u’中文’ #u暗示用unicode编码方法储存信息
s2 = unicode(‘中文’,’gbk’)
unicode是一个内置函数,第二个参数指示源字符串的编码名目。
decode是任何字符串具有的要领,将字符串转换成unicode名目,参数指示源字符串的编码名目。
encode也是任何字符串具有的要领,将字符串转换成参数指定的名目。
python字符串的编码
用 u’汉字’ 结构出来的是unicode范例,不消的话结构出来是str范例
str的编码是与系统情况相关的,一般就是sys.getfilesystemencoding()获得的值
所以从unicode转str,要用encode要领
从str转unicode,所以要用decode
#p#分页标题#e#
譬喻:
# coding=utf-8 #默认编码名目为utf-8 s = u'中文' #unicode编码的文字 print s.encode('utf-8') #转换成utf-8名目输出 print s #结果与上面沟通,好像默认直接转换为指定编码
总结:
u=u'unicode编码文字'
g=u.encode('gbk') #转换为gbk名目
print g #此时为乱码,因为当前情况为utf-8,gbk编码文字为乱码
str=g.decode('gbk').encode('utf-8') #以gbk编码名目读取g(因为他就是gbk编码的)并转换为utf-8名目输出
print str #正常显示中文
安详的要领:
s.decode('gbk','ignore').encode('utf-8′) #以gbk编码读取(虽然是读取gbk编码名目标文字了)并忽略错误的编码,转换成utf-8编码输出
因为decode的函数原型是decode([encoding], [errors='strict']),可以用第二个参数节制错误处理惩罚的计策,默认的参数就是strict,代表碰着犯科字符时抛出异常;
假如配置为ignore,则会忽略犯科字符;
假如配置为replace,则会用?代替犯科字符;
假如配置为xmlcharrefreplace,则利用XML的字符引用。