python文件操作 python文件操作

python文件操作

 

文件操作

读取文件(开 - 读 - 关)

file1 = open('/Users/Ted/Desktop/test/abc.txt',mode='r',encoding='utf-8') 

open()函数里面有三个参数:

①第一个参数是文件的保存地址,一定要写清楚,否则计算机找不到。

绝对路径和相对路径

绝对路径就是最完整的路径,相对路径指的就是【相对于当前文件夹】的路径

Windows系统里,常用\来表示绝对路径,/来表示相对路径

\在Python中是转义字符,所以时常会有冲突。为了避坑,Windows的绝对路径通常要稍作处理,可以写成以下两种方式:

open('C:\\Users\\Ted\\Desktop\\test\\abc.txt')
#将'\'替换成'\\'

open(r'C:\Users\Ted\Desktop\test\abc.txt')
#在路径前加上字母r

②第二个参数表示打开文件时的模式。这里是字符串 'r',表示 read。

③第三个参数encoding='utf-8',表示的是返回的数据采用何种编码,一般采用utf-8或者gbk。

file1 = open('/Users/Ted/Desktop/test/abc.txt','r',encoding='utf-8') 
filecontent = file1.read()            
print(filecontent)
file1.close()  
read()可以指定我们想要读取的内容数量

写入文件(开 - 写 - 关)

file1 = open('/Users/Ted/Desktop/test/abc.txt','w',encoding='utf-8') 

以写入的模式打开了文件"abc.txt"。

open() 中还是三个参数,其他都一样,除了要把第二个参数改成'w',表示write,即以写入的模式打开文件。

'w'写入模式会给你暴力清空掉文件,然后再给你写入。如果你只想增加东西,而不想完全覆盖掉原文件的话,就要使用'a'模式,表示append,你学过,它是追加的意思。

f1 = open('./1.txt','a',encoding='utf-8') 
#以追加的方式打开一个文件,尽管并不存在这个文件,但这行代码已经创建了一个txt文件了
f1.write('难念的经') #写入'难念的经'的字符串 f1.close() #关闭文件 f2 = open('./1.txt','r',encoding='utf-8') #以读的方式打开这个文件 content = f2.read() #把读取到的内容放在变量content里面 print(content) #打印变量content f2.close() #关闭文件 #结果: 难念的经

'wb'的模式,它的意思是以二进制的方式打开一个文件用于写入。因为图片和音频是以二进制的形式保存的

补充内容

with open as f

为了避免打开文件后忘记关闭,占用资源或当不能确定关闭文件的恰当时机的时候,我们可以用到关键字with,之前的例子可以写成这样:

# 普通写法
file1 = open('abc.txt','a') 
file1.write('张无忌') 
file1.close()

# 使用with关键字的写法 with open('abc.txt','a') as file1: #with open('文件地址','读写模式') as 变量名: #格式:冒号不能丢 file1.write('张无忌') #格式:对文件的操作要缩进 #格式:无需用close()关闭

readline()

readline()读取每次只读取一行,注意点:readline()读取出来的数据在后面都有一个\n

f = open('path1/小娃娃.txt',mode='r',encoding='utf-8')
msg1 = f.readline()
msg2 = f.readline()
msg3 = f.readline()
msg4 = f.readline()
f.close()
print(msg1)
print(msg2)
print(msg3)
print(msg4)

结果:
高圆圆

刘亦菲

张柏芝

杨紫

结果这里每个一内容中间都有一个空行是因为咱们读取的内容后边都带有一个\n print()的时候会将这个\n执行

f = open('path1/小娃娃.txt',mode='r',encoding='utf-8')
msg1 = f.readline().strip()
msg2 = f.readline().strip()
msg3 = f.readline().strip()
msg4 = f.readline().strip()
f.close()
print(msg1)
print(msg2)
print(msg3)
print(msg4)

结果:
高圆圆
刘亦菲
张柏芝
杨紫

readlines()

readlines() 将每一行形成一个元素,放到一个列表中,将所以的内容全部读出来,如果文件很大,占内存,容易崩盘。

f = open('log',encoding='utf-8')
print(f.readlines())
f.close()
# 结果['666666\n', 'fkja l;\n', 'fdkslfaj\n', 'dfsflj\n', 'df;asdlf\n', '\n', ]

较大的文件读取我们不推介这种方法,推介下面写法:

f = open('../path1/弟子规',mode='r',encoding='utf-8')
for line in f: print(line) #这种方式就是在一行一行的进行读取

其他操作

seek()

seek操作:seek(n)光标移动到n位置,注意: 移动单位是byte,所有如果是utf-8的中文部分要是3的倍数

seek(0,0)默认为0,移动到文件头

seek(0,1)移动到当前位置

seek(0,2)移动到文件尾

f = open("小娃娃", mode="r+", encoding="utf-8")
f.seek(0) # 光标移动到开头 content = f.read() # 读取内容, 此时光标移动到结尾 print(content) f.seek(0) # 再次将光标移动到开头 f.seek(0, 2) # 将光标移动到结尾 content2 = f.read() # 读取内容. 什么都没有 print(content2) f.seek(0) # 移动到开头 f.write("张国荣") # 写入信息. 此时光标在9 中文3 * 3个 = 9 f.flush() f.close()  tell()

tell()

使用tell()可以帮我们获取当前光标在什么位置

f = open("小娃娃", mode="r+", encoding="utf-8")
f.seek(0) # 光标移动到开头 content = f.read() # 读取内容, 此时光标移动到结尾 print(content) f.seek(0) # 再次将光标移动到开头 f.seek(0, 2) # 将光标移动到结尾 content2 = f.read() # 读取内容. 什么都没有 print(content2) f.seek(0) # 移动到开头 f.write("张国荣") # 写入信息. 此时光标在9 中⽂文3 * 3个 = 9 print(f.tell()) # 光标位置9 f.flush() f.close()

修改文件

文件修改: 只能将文件中的内容读取到内存中, 将信息修改完毕, 然后将源文件删除, 将新文件的名字改成老文件的名字.

import os
with open("../path1/小娃娃", mode="r", encoding="utf-8") as f1,\ open("../path1/小娃娃_new", mode="w", encoding="UTF-8") as f2: content = f1.read() new_content = content.replace("冰糖葫芦", "⼤白梨") f2.write(new_content) os.remove("../path1/小娃娃") # 删除源文件 os.rename("../path1/小娃娃_new", "小娃娃") # 重命名新文件

弊端: ⼀次将所有内容进行读取. 内存溢出. 解决方案: 一行一行的读取和操作

import os
with open("小娃娃", mode="r", encoding="utf-8") as f1,\ open("小娃娃_new", mode="w", encoding="UTF-8") as f2: for line in f1: new_line = line.replace("大白梨", "冰糖葫芦") f2.write(new_line) os.remove("小娃娃") # 删除源⽂文件 os.rename("小娃娃_new", "小娃娃") # 重命名新文件

文件操作

读取文件(开 - 读 - 关)

file1 = open('/Users/Ted/Desktop/test/abc.txt',mode='r',encoding='utf-8') 

open()函数里面有三个参数:

①第一个参数是文件的保存地址,一定要写清楚,否则计算机找不到。

绝对路径和相对路径

绝对路径就是最完整的路径,相对路径指的就是【相对于当前文件夹】的路径

Windows系统里,常用\来表示绝对路径,/来表示相对路径

\在Python中是转义字符,所以时常会有冲突。为了避坑,Windows的绝对路径通常要稍作处理,可以写成以下两种方式:

open('C:\\Users\\Ted\\Desktop\\test\\abc.txt')
#将'\'替换成'\\'

open(r'C:\Users\Ted\Desktop\test\abc.txt')
#在路径前加上字母r

②第二个参数表示打开文件时的模式。这里是字符串 'r',表示 read。

③第三个参数encoding='utf-8',表示的是返回的数据采用何种编码,一般采用utf-8或者gbk。

file1 = open('/Users/Ted/Desktop/test/abc.txt','r',encoding='utf-8') 
filecontent = file1.read()            
print(filecontent)
file1.close()  
read()可以指定我们想要读取的内容数量

写入文件(开 - 写 - 关)

file1 = open('/Users/Ted/Desktop/test/abc.txt','w',encoding='utf-8') 

以写入的模式打开了文件"abc.txt"。

open() 中还是三个参数,其他都一样,除了要把第二个参数改成'w',表示write,即以写入的模式打开文件。

'w'写入模式会给你暴力清空掉文件,然后再给你写入。如果你只想增加东西,而不想完全覆盖掉原文件的话,就要使用'a'模式,表示append,你学过,它是追加的意思。

f1 = open('./1.txt','a',encoding='utf-8') 
#以追加的方式打开一个文件,尽管并不存在这个文件,但这行代码已经创建了一个txt文件了
f1.write('难念的经') #写入'难念的经'的字符串 f1.close() #关闭文件 f2 = open('./1.txt','r',encoding='utf-8') #以读的方式打开这个文件 content = f2.read() #把读取到的内容放在变量content里面 print(content) #打印变量content f2.close() #关闭文件 #结果: 难念的经

'wb'的模式,它的意思是以二进制的方式打开一个文件用于写入。因为图片和音频是以二进制的形式保存的

补充内容

with open as f

为了避免打开文件后忘记关闭,占用资源或当不能确定关闭文件的恰当时机的时候,我们可以用到关键字with,之前的例子可以写成这样:

# 普通写法
file1 = open('abc.txt','a') 
file1.write('张无忌') 
file1.close()

# 使用with关键字的写法 with open('abc.txt','a') as file1: #with open('文件地址','读写模式') as 变量名: #格式:冒号不能丢 file1.write('张无忌') #格式:对文件的操作要缩进 #格式:无需用close()关闭

readline()

readline()读取每次只读取一行,注意点:readline()读取出来的数据在后面都有一个\n

f = open('path1/小娃娃.txt',mode='r',encoding='utf-8')
msg1 = f.readline()
msg2 = f.readline()
msg3 = f.readline()
msg4 = f.readline()
f.close()
print(msg1)
print(msg2)
print(msg3)
print(msg4)

结果:
高圆圆

刘亦菲

张柏芝

杨紫

结果这里每个一内容中间都有一个空行是因为咱们读取的内容后边都带有一个\n print()的时候会将这个\n执行

f = open('path1/小娃娃.txt',mode='r',encoding='utf-8')
msg1 = f.readline().strip()
msg2 = f.readline().strip()
msg3 = f.readline().strip()
msg4 = f.readline().strip()
f.close()
print(msg1)
print(msg2)
print(msg3)
print(msg4)

结果:
高圆圆
刘亦菲
张柏芝
杨紫

readlines()

readlines() 将每一行形成一个元素,放到一个列表中,将所以的内容全部读出来,如果文件很大,占内存,容易崩盘。

f = open('log',encoding='utf-8')
print(f.readlines())
f.close()
# 结果['666666\n', 'fkja l;\n', 'fdkslfaj\n', 'dfsflj\n', 'df;asdlf\n', '\n', ]

较大的文件读取我们不推介这种方法,推介下面写法:

f = open('../path1/弟子规',mode='r',encoding='utf-8')
for line in f: print(line) #这种方式就是在一行一行的进行读取

其他操作

seek()

seek操作:seek(n)光标移动到n位置,注意: 移动单位是byte,所有如果是utf-8的中文部分要是3的倍数

seek(0,0)默认为0,移动到文件头

seek(0,1)移动到当前位置

seek(0,2)移动到文件尾

f = open("小娃娃", mode="r+", encoding="utf-8")
f.seek(0) # 光标移动到开头 content = f.read() # 读取内容, 此时光标移动到结尾 print(content) f.seek(0) # 再次将光标移动到开头 f.seek(0, 2) # 将光标移动到结尾 content2 = f.read() # 读取内容. 什么都没有 print(content2) f.seek(0) # 移动到开头 f.write("张国荣") # 写入信息. 此时光标在9 中文3 * 3个 = 9 f.flush() f.close()  tell()

tell()

使用tell()可以帮我们获取当前光标在什么位置

f = open("小娃娃", mode="r+", encoding="utf-8")
f.seek(0) # 光标移动到开头 content = f.read() # 读取内容, 此时光标移动到结尾 print(content) f.seek(0) # 再次将光标移动到开头 f.seek(0, 2) # 将光标移动到结尾 content2 = f.read() # 读取内容. 什么都没有 print(content2) f.seek(0) # 移动到开头 f.write("张国荣") # 写入信息. 此时光标在9 中⽂文3 * 3个 = 9 print(f.tell()) # 光标位置9 f.flush() f.close()

修改文件

文件修改: 只能将文件中的内容读取到内存中, 将信息修改完毕, 然后将源文件删除, 将新文件的名字改成老文件的名字.

import os
with open("../path1/小娃娃", mode="r", encoding="utf-8") as f1,\ open("../path1/小娃娃_new", mode="w", encoding="UTF-8") as f2: content = f1.read() new_content = content.replace("冰糖葫芦", "⼤白梨") f2.write(new_content) os.remove("../path1/小娃娃") # 删除源文件 os.rename("../path1/小娃娃_new", "小娃娃") # 重命名新文件

弊端: ⼀次将所有内容进行读取. 内存溢出. 解决方案: 一行一行的读取和操作

import os
with open("小娃娃", mode="r", encoding="utf-8") as f1,\ open("小娃娃_new", mode="w", encoding="UTF-8") as f2: for line in f1: new_line = line.replace("大白梨", "冰糖葫芦") f2.write(new_line) os.remove("小娃娃") # 删除源⽂文件 os.rename("小娃娃_new", "小娃娃") # 重命名新文件

猜你喜欢

转载自www.cnblogs.com/zh718594493/p/12358091.html