1.文件操作基本流程
计算机系统分为:计算机硬件,操作系统,应用程序三部分。
我们用python或其他语言编写的应用程序若想要把数据永久保存下来,必须要保存于硬盘中,这就涉及到应用程序要操作硬件,众所周知,应用程序是无法直接操作硬件的,这就用到了操作系统。操作系统把复杂的硬件操作封装成简单的接口给用户/应用程序使用,其中文件就是操作系统提供给应用程序来操作硬盘虚拟概念,用户或应用程序通过操作文件,可以将自己的数据永久保存下来。
有了文件的概念,我们无需再去考虑操作硬盘的细节,只需要关注操作文件的流程:
f=open('a.txt','r',encoding='utf-8') #默认打开模式就为r
2. 通过句柄对文件进行操作
data=f.read()
3. 关闭文件
f.close()
关闭文件的注意事项:
打开一个文件包含两部分资源:操作系统级打开的文件+应用程序的变量。在操作完毕一个文件时,必须把与该文件的这两部分资源一个不落地回收,回收方法为:
1、f.close() #回收操作系统级打开的文件
2、del f #回收应用程序级的变量
其中del f一定要发生在f.close()之后,否则就会导致操作系统打开的文件还没有关闭,白白占用资源,
而python自动的垃圾回收机制决定了我们无需考虑del f,这就要求我们,在操作完毕文件后,一定要记住f.close()
虽然我这么说,但是很多同学还是会很不要脸地忘记f.close(),对于这些不长脑子的同学,我们推荐傻瓜式操作方式:使用with关键字来帮我们管理上下文
with open('a.txt','w') as f:
pass
with open('a.txt','r') as read_f,open('b.txt','w') as write_f:
data=read_f.read()
write_f.write(data)
2. 文件操作
以什么编码方式储存的文件,就以什么编码打开进行操作
2.1 只读
r
rb 需要打开非文字类的文件,不需要添加encoding参数
f = open('lll', mode='r', encoding='utf-8') # 打开的文件是什么编码方式,就写对应的encoding值
content = f.read() # open函数帮助转化为unicode,方便用户读
print(content)
f.close()
2.2 只写
w 没有文件就会创造,有的话先清除内容再写
wb 以bytes类型写,不添加encoding参数,在写入内容的后面加.encode('utf-8')
# w f = open('log', mode='w', encoding='utf-8') f.write('高清电影') f.close() # wb f = open('log', mode='wb') f.write('高清附近看看纷纷'.encode('utf-8')) f.close()
2.3 追加
a
ab 以bytes类型追加,写入内容的后面加.encode('utf-8')
f = open('log',mode = 'a', encoding='utf-8')
f.write('好的男孩你加油')
f.close() # 追加 光标自动移动到最后一位
2.4 读写(先读后写)
r+ 读完之后光标停留在最后,在进行追加写
r+b 以bytes类型读写,写入内容的后面加.encode('utf-8')
f = open('log', mode= 'r+',encoding= 'utf-8')
print(f.read())
f.write('大梦,小梦')
f.close() # 光标停留在读结束后,所以属于追加
2.5 写读
w+ 先清除再写,读的时候只显示未被覆盖的内容,所以如果不调整光标位置就什么也读不到
f = open('log', mode= 'r+',encoding= 'utf-8')
f.write('aaa') # 会覆盖
print(f.read()) # 只显示未被覆盖的内容,所以什么也读不到
f.close()
改进:
f = open('log',mode= 'r+',encoding='utf-8')
f.write('佳琪')
f.seek(0) # 将光标移动到开头,才能全部都出
print(f.read()) # 读的操作是从光标位置,到文件末尾
f.close()
2.6 光标问题
seek() 按照字节定光标的位置
f = open('log', mode='r+', encoding='utf-8') f.seek(3) # 所以光标是按照字节定位置的,在utf-8编码中,3个字节是一个文字 # log文件中的内容 爱国爱党爱业 content = f.read() print(content) # 结果: 国爱党爱业
f.close()
tell() 显示光标当前位置
f = open('log',mode= 'a+',encoding='utf-8') f.write('佳琪') # 此时文档的内容为 爱国爱党爱业佳琪
count = f.tell() # 光标落到最后
f.seek(count - 9)
print(f.read()) # 结果 : 业佳琪
f.close()
2.7 对句柄循环打印,读全文化
f = open('log',mode= 'r+',encoding='utf-8')
for line in f:
print(line)
3.当日练习
1. 文件a.txt内容:每一行内容分别为商品名字,价钱,个数。
apple 10 3
tesla 100000 1
mac 3000 2
lenovo 30000 3
chicken 10 3
通过代码,将其构建成这种数据类型:[{'name':'apple','price':10,'amount':3},{'name':'tesla','price':1000000,'amount':1}......] 并计算出总价钱。
2,有如下文件:
-------
alex是老男孩python发起人,创建人。
alex其实是人妖。
谁说alex是sb?
你们真逗,alex再牛逼,也掩饰不住资深屌丝的气质。
----------
将文件中所有的alex都替换成大写的SB。