python - 文件操作
一.文件操作
1. 初识⽂文件操作
2. 只读(r, rb)
3. 只写(w, wb)
4. 追加(a, ab)
5. r+读写
6. w+写读
7. a+写读(追加写读)
8. 其他操作⽅方法
9. ⽂文件的修改以及另⼀一种打开⽂文件句句柄的⽅方式
二.文件的绝对路径和相对路径:
1.相对路径:相当于你当前程序所在的文件夹. ../表示上一层文件夹
2.绝对路径:1.从磁盘根目录寻找. 2.互联网上的一个绝对路径
三. 只读操作(r, rb)
s = open("沙县小吃",mode="r",encoding="utf-8") a = s.read() s.close() #关闭句柄 print(a)
1.encoding表示编码集.
2. rb. 读取出来的数据是bytes类型, 在rb模式下. 不能选择encoding字符集.
f = open("沙县小吃",mode="rb") s = f.read() print(s.decode("utf-8")) f.close()
3.读取文件的⽅方法:
1. read() 将文件中的内容全部读取出来. 弊端: 占内存. 如果文件过大.容易导致内存崩溃
2.read(n) 读取n个字符. 需要注意的是. 如果再次读取. 那么会在当前位置继续去读而不是从头读, 如果使⽤的是rb模式. 则读取出来的是n个字节
3. readline() ⼀次读取⼀行数据, 注意: readline()结尾, 注意每次读取出来的数据都会有⼀一个\n 所以呢. 需要我们使用strip()方法来去掉\n或者空格
4. readlines()将每⼀行形成一个元素, 放到⼀个列表中. 将所有的内容都读取出来. 所以也是. 容易出现内存崩溃的问题.不推荐使用
四. 写模式(w, wb)
1.写的时候注意. 如果没有文件. 则会创建文件, 如果文件存在. 则将原件中原来的内容删除, 再写入新内容
f = open("面包店",mode="w",encoding="utf-8") f.write("豆沙面包") f.flush() # 刷新 f.close()
2.wb模式下. 可以不指定打开文件的编码. 但是在写文件的时候必须将字符串转化成utf-8的 bytes数据
f = open("沙县小吃",mode='wb') f.write("包子".encode('utf-8')) f.flush() f.close()
五. 追加(a, ab)
1.在追加模式下. 我们写入的内容会追加在文件的结尾.
f = open("面包店",mode="a",encoding="utf-8") f.write("玫瑰花包") f.flush() f.close()
六. 读写模式(r+, r+b)
1. 对于读写模式. 必须是先读. 因为默认光标是在开头的. 准备读取的. 当读完了之后再进⾏写入. 我们以后使⽤频率最高的模式就是r+
f = open('../面包店',mode='r+',encoding="utf-8") s1 = f.read(3) #1.不管你前面读了几个,后面去写都是在末尾 f.write("牛肉堡") # 2.在没有任何操作之前去写,则在开头写 print(s1) f.close()
七. 写读(w+, w+b)
1.先将所有的内容清空. 然后写入. 最后读取. 但是读取的内容是空的, 不常⽤
f = open("面包店",mode='w+',encoding='utf-8') f.write("玫瑰豆沙") # w写会先清除之前的内容 f.flush() f.seek(0) #移动光标 s = f.read() print(s) f.close()
八.追加读(a+)
1.a+模式下, 不论先读还是后读. 都是读取不到数据的.
f = open("面包店",mode='a+',encoding='utf-8') f.write("玫瑰豆沙") s = f.read() print(s) f.flush() f.close()
九.其他相关操作
1. seek(n) 光标移动到n位置, 注意, 移动的单位是byte. 所以如果是UTF-8的中⽂部分要是3的倍数.
移动到开头: seek(0)
移动到结尾: seek(0,2) seek的第⼆个参数表示的是从哪个位置进行偏移, 默认是0, 表示开头, 1表示当前位置, 2表⽰结尾
f = open('面包店',mode="r+",encoding="utf-8") f.seek(6) #移动光标到xx位置,光标读取6个字节 s = f.read(3) # 读取3个字 ss = f.read(3) print(s) print(ss) f.close()
2. tell() 使用tell()可以帮我们获取到当前光标在么位置
f = open('面包店',mode="r+",encoding="utf-8") f.seek(6) #移动光标到xx位置,光标读取6个字节 s = f.read(3) print(s) print(f.tell()) f.close()
3.truncate() 截断文件
f = open("⼩小娃娃", mode="w", encoding="utf-8") f.write("哈哈") f.seek(3) # 光标移动到3, 也就是两个字中间 f.truncate() # 删掉光标后面的所有内容 f.close()
十. 修改文件以及另⼀种打开文件的方式
文件修改: 只能将文件中的内容读取到内存中, 将信息修改完毕, 然后将原文件删除, 将新文件的名字改成老文件的名字.
import os with open("花店",mode='r',encoding='utf-8') as f1,\ open('花店副本',mode='w',encoding='utf-8') as f2: # s = f1.read() # ss = s.replace('花',"hua") # f2.write(ss) # f2.flush() for line in f1: s = line.replace("花",'hua') f2.write(s) f2.flush() os.remove('花店') os.rename("花店副本",'花店')
11.冒号:循环
for s in range(7): i = 0 while i < len(lst)-1: if lst[i] > lst[i+1]: lst[i],lst[i+1] = lst[i+1],lst[i] i = i + 1 print(lst)