文件处理二
文件处理二
一、文本打开模式
# 'r'的用法:只读,若没有该文件会报错
f = open(r'1.txt',mode="r",encoding="utf-8")#r的作用是防止转义
print(f.read())#read的类型是读完之后光标就跑到末尾,所以第二次打印以后会看不到内容
# print(f.read())
f.close()
>>>亚峰666
燃烧吧
月薪30k
月薪30k
月薪30k
#'rb'的用法
f = open(r'a.txt',mode='rb')#此时不需要encoding=,因为已经是二进制模式
print(f.read())
f.close()
>>>b'\xe6\x9c\x88\xe8\x96\xaa30k\xe5\x8a\xa0\xe6\xb2\xb9\xe5\x8a\xa0\xe6\xb2\xb9'
#'w'的用法:只写,若没有就新建一个文件,若改文件存在会先删除原文件中的内容,然后重新写入
f = open(r'2.txt',mode='w',encoding='utf-8')
f.write("亚峰加油啊,你是最棒的")
f.close()
>>>亚峰加油啊,你是最棒的
#'wb'的用法
f = open(r'3.txt',mode='wb')#bytes类型
f.write("亚峰666".encode('utf-8'))#此时是字符串类型,需用变成“wb”类型,即用.encode
f.close()
>>>亚峰666
#'a'的用法
f = open(r'3.txt',mode='a',encoding='utf-8')
f.write("\n燃烧吧")
f.close()
>>>亚峰666
燃烧吧
#'r+w'的用法,#先读后写
f = open(r'3.txt',mode='r+',encoding='utf-8')
print(f.read())
f.write("\n月薪30k")
f.close()
>>>亚峰666
燃烧吧
月薪30k
#'r+b'也是读写(以byte类型)
f = open(r'3.txt',mode='r+b')
print(f.read())
f.write("月薪30k".encode('utf-8'))#先写后读光标会从第一个开始,也就是会替换你原先的内容,若光标过长,就替换全部
f.close()
>>>b'\xe4\xba\x9a\xe5\xb3\xb0666\r\n\xe7\x87\x83\xe7\x83\xa7\xe5\x90\xa7\xe6\x9c\x88\xe8\x96\xaa30k'
#'w+'的用法
f = open('a.txt',mode='w+',encoding='utf-8')
f.write("月薪30k")#先写后读光标会从第一个开始,也就是会替换你原先的内容,若光标过长,就替换全部
print(f.read())
f.close()
>>>亚峰666
燃烧吧月薪30k月薪30k
#'a+'的用法
f = open('1.txt',mode='a+',encoding='utf-8')
f.write("\n月薪30k")
f.seek(0)#光标从0 开始
print(f.read())
f.close()
>>>亚峰666
燃烧吧
月薪30k
月薪30k
月薪30k
月薪30k
二、其他玩法
#read
f = open('a.txt',mode='r+',encoding='utf-8')
content = f.read(3)#读出来的都是字符,可指定读取个数
print(content)
f.close()
>>>月薪3
#seek
f = open('a.txt',mode='r+',encoding='utf-8')
f.seek(3)#是按照字节去定光标,注意一个中文三个字符
content = f.read()
print(content)
f.close()
>>>薪30k加油加油加油
#tell
f = open('a.txt',mode='a+',encoding='utf-8')
f.write('加油')
# print(f.tell())#告诉你光标的位置
count = f.tell()
f.seek(count-9)#向前移动9个字符
print(f.read(2))#只读2个字符
f.close()
>>>油加
with open(r"a.txt", mode='w')as f:
#注意 f.write('[]')不可以列表
f.writelines(['1','l']) # for + f.write#改模式则可以,但列表中的内容必须为字符串,不可为其他类 型
三、小应用
- 写入文本
import time
res = time.strftime('%Y-%m-%d %H:%M:%S')#时间库获取年月日,时
with open(r'01.txt','a',encoding='utf-8')as f:
for i in range(10):
f.write(f'{res}:马上要学函数了,有点难,怎么办\n')
- 获取文件实时动态
import time
with open(r"a.txt", 'r', encoding='utf-8')as f:
# f.seek(0, 2) # 以文件末尾为参照点,移动0位
while True:
# time.sleep()
res = f.readline() # 一次读一行
if res: # 如果你读出数据了,就执行下面的代码块
print(f'录入记录:{res}')
四、修改文件内容
# 第一方案
with open(r'02.txt','r',encoding='utf-8')as f:
data = f.read()
print(data)
print(type(data))
with open(r'02.txt','w',encoding='utf-8')as f:
res = data.replace('副书记','亚峰牛批')
f.write(res)
with open(r'02.txt','r',encoding='utf-8')as rf,\
open(r'02.txt','a',encoding='utf-8')as wf:
data = rf.read()
res = data.replace('副书记', '亚峰牛批')
wf.seek(0,0)
wf.write(res)
>>>几哈亚峰牛批公积金卡的国家几哈亚峰牛批公积金卡的国家
<class 'str'>
#第二种方案
import os
with open(r'02.txt','r',encoding='utf-8')as rf,\
open(r'03_wap.txt','w',encoding='utf-8')as wf:
data = rf.read()
res = data.replace('公积金', '亚峰666')
wf.write(res)
os.remove('02.txt')
os.rename('03_wap.txt','b.txt')
>>>几哈亚峰牛批亚峰666卡的国家几哈亚峰牛批亚峰666卡的国家几哈亚峰牛批亚峰666卡的国家几哈亚峰牛批亚峰666卡的国家
Only you can control your future
You're not alone. You still have family,peopel who care for you and want to save you.