七、文件操作
(一)打开
1.格式
<变量名> = open("<路径>\<文件名.txt>",“<打开模式>")
with 上下文管理
""" with open("<路径>\\<文件名.txt>",“<打开模式>",encoding="utf-8") as <变量>[, ]: #加上with,操作完文件不需要.close,会自动关闭 ;encoding可以是其他编码 文件操作 """
txt = open(r"C:\a\a\txt.txt","x") txt = open("txt.txt","w") #相对路径,txt文件要与py文件处于同一文件
2.打开模式
(二)读取
readall() 读取全文,以字符串表示 read(size) #前size长度的字符串,不填,则读取全部 a.readline(size) 读取一行,size一行字符数 readlines(hint) 读取多行以列表表示,hint行数
#通用的复制器----使用b模式
def copy(url,url2):
"""
url :被复制的文件的路径
url2:新文件
"""
with open(url,"rb") as f1,open(url2,"wb") as f2:
for item in f1: #读出每行
f2.write(item) #写进每行
copy("4010173121.jpg","js18150322.jpg")
(三)写
write(s) #s必须是字符串或二进制 writelines(lines)
# 打开文件
fo = open("test.txt", "w")
print ("文件名为: ", fo.name)
seq = ["菜鸟教程 1\n", "菜鸟教程 2"]
fo.writelines( seq )
# 关闭文件
fo.close()
文本修改
#方法1, 占用额外的内存,造成内存浪费
with open("c.txt",mode="rt",encoding="utf-8")as f:
res = f.read()
data = res.replace("<旧字符>","<新字符>")
with open("c.txt",mode="wt",encoding="utf-8") as f1:
f1.write(data)
#方法二 占用额外的硬盘空间
import os
with open("c.txt",mode="rt",encoding="utf-8") as f,\
with open("c.txt.swap",mode="rt",encoding="utf-8") as f1:
for item in f:
f1.write(item.replace("",""))
os.remove("c.txt")
os.rename("c.txt.swap","c.txt")
(四)seek
seek(offset[,whence])
-
offset -- 开始的偏移量,也就是代表需要移动偏移的字节数,如果是负数表示从倒数第几位开始。
-
whence:可选,默认值为 0。给 offset 定义一个参数,表示要从哪个位置开始偏移;0 代表从文件开头开始算起,1 代表从当前位置开始算起,2 代表从文件末尾算起。
-
如果操作成功,则返回新的文件位置,如果操作失败,则函数返回 -1。
>>> f = open('workfile', 'rb+') >>> f.write(b'0123456789abcdef') 16 >>> f.seek(5) # 移动到文件的第六个字节 5 >>> f.read(1) b'5' >>> f.seek(-3, 2) # 移动到文件倒数第三个字节 13 >>> f.read(1) b'd'
(五)关闭
.close()