python

python 文件处理

2018-05-15  本文已影响0人  little_short
文件处理
1、打开文件,得到文件的句柄并赋值给一个变量  open() 函数指定解码方式  默认gbk
2、通过句柄对文件进行操作
3、关闭文件

读
f = open('6.py','r',encoding='utf-8')
data = f.read()
print(data)
print('readable',f.readable())
f1 = f.readline()
print('one',f1)
f.close()
写
f = open('text','w',encoding='utf-8')

f.write('111111\n')
f.write('222222\n')
f.writable()
f.writelines(['1111\n','2222'])

f.close()
追加
f = open('text','a',encoding='utf-8')

f.write('\n2132321\n')

f.close()

f = open('text','r+',encoding='utf-8')
print(f.read())
f.write('\n2132321\n')
f.close()

with open('a','r',encoding='utf-8') as src_f,\
    open('a_w', 'w', encoding='utf-8') as der_f:
    data = src_f.read()
    der_f.write(data)

文件处理b 模式  b 模式不指定编码

f = open('a','rb')

data = f.read()
print(data)

print(data.decode('utf-8'))


f = open('c','wb')


f.write(bytes('123123123123\n',encoding='utf-8'))
x = '123123123123'

f.write(x.encode('utf-8'))

f = open('a.txt','w')
print(f.closed)
print(f.encoding)

拉丁编码
f = open('c','r+',encoding='gb2312')
f.write('23ds')

f = open('c','r+',encoding='latin-1')

f = open('c','r+',encoding='utf-8')
f.readline()
f.seek(1) 光标位置
print(f.tell())

f = open('c','r+',encoding='utf-8')

f.truncate(10)

seek() 方法补充  光标移动从开始开始数 # seek()  三种模式  0,1,2
f = open('seek.txt','rb')

f.seek(3)

print(f.tell())

f.seek(10,1)
print(f.tell())
f.seek(3,1)

print(f.tell())


f = open('seek.txt','rb')

print(f.tell())
f.seek(-3,2)

print(f.tell())
print(f.read())


循环文件的方式

for i in f:
    print(i)

拿取文件最后一行
f = open('seek.txt', 'rb')
for i in f:
    offs = -10
    while True:
        f.seek(offs, 2)
        data = f.readlines()
        if len(data) > 1:
            print('last%s' %(data[-1].decode('utf-8')))
            break
        offs*=2
上一篇 下一篇

猜你喜欢

热点阅读