python文件操作
1. 文件操作
open 打开
f = open(文件路径, mode="模式", encoding="编码格式") 最最底层操作的就是bytes
打开一个文件的时候获取到的是一个文件句柄.
绝对路径
从磁盘根目录开始寻找
相对路径
相对于当前程序所在的文件夹
../ 上一层文件
文件夹/ 进入xxx文件夹
1 f= open("D:\西游记\金角大王吧.txt", mode="r", encoding="gbk") 2 print(f.read()) 3 f.close()
2. mode:
r: 读取,只读.
读取文件的相关操作
1. read()
默认: 读取文件内容(全部)
read(n) 读取n个字符
2. readline() 读取一行
3. readlines() 读取全部. 返回列表
(最重要)4. for line in f: 每次读取一行内容
1 f = open("moder.txt", mode="r", encoding="utf-8") 2 print(f.read(5)) # 读取5个字符 3 print(f.read(5)) #继续读5个 4 print(f.readline().strip()) # 换行符为分割,strip()可以去掉换行. 读取到的内容第一件事就是去掉空白 5 print(f.readline()) 6 f.close() 7 8 print(f.readlines()) #一次性把文件中的内容读取到列表中 9 10 #文件句柄是一个可迭代对象 11 #优点:相对来说节省内存,操作相对简单一点 12 for line in f: # 从文件中读取到每一行给前面的line 13 print(line.strip()) 14 f.close()
w:
写入. 只写
创建文件
会清空文件
1 # 每次用w模式打开文件,都会清空这个文件(坑) 2 f = open('胡辣汤', mode='w', encoding="utf-8") # 可以帮我们创建文件 3 4 f.write('河南特色\n') 5 f.write("东北特色\n") 6 f.write("陕西特色\n") 7 8 # 好习惯 9 f.flush() #刷新管道, 把数据写入文件 10 f.close()
a:
也可以创建文件
追加写
f = open("葫芦小金刚", mode="a", encoding="utf-8") # a, append 追加, 在文件末尾写入内容 f.write("你叫什么名字阿?") # f.read() #not readable f.flush() f.close()
r+: 对于文件而言. 应该有的操作就两个:读, 写
读写操作
1 f = open("葫芦小金刚", mode="r+", encoding="utf-8") 2 content = f.read() # 顺序必须先读,后写 3 # r+特有的深坑:不论读取内容的是多少,只要你读了.写就是在末尾 4 f.write('五娃') 5 print(content)
w+:
写读操作
1 # 一上来会清空文件, 没人用 2 f = open("葫芦小金刚", mode="w+", encoding="utf-8") 3 # content = f.read() # 顺序必须先读,后写 4 # # r+特有的深坑:不论读取内容的是多少,只要你读了.写就是在末尾 5 # f.write('五娃') 6 f.write("有能吐火的, 有能吐水的") 7 # 移动光标 8 f.seek(0) # 移动到开头 9 s = f.read() 10 print("========>", s)
a+:
追加写读
所有带b的表示直接操作的是bytes, 当处理非文本文件的时候.
# 追加写读, 光标在末尾. 所有的写都是在末尾
f = open("葫芦小金刚", mode="a+", encoding="utf-8")
f.write("机械葫芦娃召唤神龙, 高喊. 我代表月亮消灭你!")
f.seek(0)
s =f.read()
print("=====>", s)
rb
wb
ab: 断点续传
r+b
w+b
a+b
3.文件复制
1 f1 = open("E:/1.png", mode="rb") 2 3 f2 = open("D:/1.png", mode="wb") 4 5 for line in f1: # line是从f1中读取的内容 6 f2.write(line) # 把读取的内容原封不动的写出去 7 8 f1.close() 9 f2.flush() 10 f2.close()
4.seek和tell
1 f = open("胡辣汤", mode="r+", encoding="utf-8") 2 f.seek(0, 2) # 移动到末尾 3 # content = f.read() 4 # print(content) 5 # f.seek(0) # 移动到开头 6 # print(f.read()) 7 # print(f.tell()) # 字节 8 9 f.seek(3) 10 print(f.read())
5.文件修改
1 f = open("夸一夸alex", mode="r", encoding="utf-8") 2 f2 = open("夸一夸alex_副本", mode="w", encoding="utf-8") 3 4 for line in f: 5 if "好人" in line: 6 line = line.replace("好人", "sb") 7 f2.write(line) 8 f.close() 9 f2.flush() 10 f2.close() 11 12 os.remove("夸一夸alex") 13 14 os.rename("夸一夸alex_副本", "夸一夸alex") 15 16 with open("夸一夸alex", mode="r", encoding="utf-8") as f, \ 17 open("夸一夸alex_副本", mode="w", encoding="utf-8") as f2: 18 for line in f: 19 if "好人" in line: 20 line = line.replace("好人", "sb") 21 f2.write(line) 22 23 os.remove("夸一夸alex") 24 os.rename("夸一夸alex_副本", "夸一夸alex")
6.水果统计
1 f = open("水果.txt", mode="r", encoding="utf-8") 2 line = f.readline().strip() 3 title = line.split(",") # ['编号','名称','价格','数量','哈哈'] 4 lst = [] 5 6 for line in f: # 1,香蕉, 1.85, 50 7 dic = {} # 每行都是一个字典 8 line = line.strip() # 去掉空白 \n 1, 香蕉, 1.85, 50 9 data = line.split(",") # [1, 香蕉, 1.85, 50] 10 11 for i in range(len(title)): 12 dic[title[i]] = data[i] 13 14 lst.append(dic) 15 16 print(lst)