Python文件读写详解及配置文件的字符编码
当前位置:以往代写 > Python教程 >Python文件读写详解及配置文件的字符编码
2019-06-14

Python文件读写详解及配置文件的字符编码

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的字符引用。

    关键字:

在线提交作业