前言
本次内容主要介绍文件处理open函数以及路径处理。
一、open函数
根据前面介绍的函数调用方式,调用open函数。
#open函数调用
open()
TypeError: open() missing required argument 'file' (pos 1)
我们发现报错了TypeError,缺少一个位置参数file。open函数是python的一个内置函数,查看源码,我们可以看到open函数有7个参数,包括1个位置参数file和6个默认参数。
def open(file, mode='r', buffering=None, encoding=None, errors=None, newline=None, closefd=True):
创建一个名称为“open函数.txt"的文件,再次调用open函数。
法外狂徒张三
王二狗
今天星期日
open('open函数.txt')
Process finished with exit code 0
调用成功,但是文件未打印内容,那么该如何获取”open函数.txt“的内容呢?
1、文件读取
根据前面所介绍的,函数有返回值,那我们试着直接通过返回值打印出来。
#open函数调用
f= open('open函数.txt')
print(f)
<_io.TextIOWrapper name='open函数.txt' mode='r' encoding='cp936'>
Process finished with exit code 0
不难看出,打印出的内容是一个io的文件对象,后面我们可以通过”对象.方法"的形式调用函数。
read():读取文件内容。读取的结果是字符串
#open函数调用
f= open('open函数.txt')
f.read()
#报错
Traceback (most recent call last):
File "E:\python_workspaces\python基础语法\文件和路径处理\open函数.py", line 3, in <module>
f.read()
UnicodeDecodeError: 'gbk' codec can't decode byte 0xa4 in position 4: illegal multibyte sequence
Process finished with exit code 1
如上所述,这里报错了,UnicodeDecodeError,文件编码错误,现在我们调整open函数传参的编码方式为utf8,并再次调用
#open函数调用
f= open('open函数.txt',encoding="utf8")
cont = f.read()
print(cont)
#运行结果
法外狂徒张三
王二狗
今天星期日
readline():读取文件内容,只读取一行内容。
#open函数调用
f= open('open函数.txt',encoding="utf8")
content = f.read()
print(content)
#readline()
cont=f.readline()
print(cont)
#运行结果
法外狂徒张三
王二狗
今天星期日
根据以上运行结果,我们可以看到打印的是第一次读取的内容,content。相当于readline没起作用?这是为什么呢?
当我们看书的时候,眼睛会跟着字体一起移动,当内容读完后,眼睛此时的位置会在文章的最后一个字,同理,当文件读取后,光标的位置就移动到文件的最后了,那么再次读取的时候已经没有内容了。
解决方法1:重新打开文件,然后调用函数读取文件内容
#open函数调用
f= open('open函数.txt',encoding="utf8")
content = f.readline()
print(content)
#运行结果
法外狂徒张三
解决方法2:移动文件光标位置到文件开头,然后重新读取文件内容。
#open函数调用
f= open('open函数.txt',encoding="utf8")
content = f.read()
print(content)
#移动光标位置
f.seek(0)
#readline()
cont=f.readline()
print(cont)
#运行结果:
法外狂徒张三
王二狗
今天星期日
法外狂徒张三
readlines():读取文件内容,读取所有的内容。以列表的形式打印出来。
f= open('open函数.txt',encoding="utf8")
content = f.readlines()
print(content)
#运行结果
['法外狂徒张三\n', '王二狗\n', '今天星期日']
2、文件写入
write():文件写入
#open函数调用
f= open('write.txt',encoding="utf8")
#文件写入
f.write('少女的腿毛')
#运行结果
io.UnsupportedOperation: not writable
从上面可以看到,文件写入报错了。找不到write.txt的这个文件。这是我们在文件写入的时候缺少一个参数mode='w'
#open函数调用
f= open('write.txt',encoding="utf8",mode='w')
#文件写入
f.write('少女的腿毛')
打开'write.txt'文件,出现了“少女的腿毛”字样。
重新写入“少女的腿毛2”,
#open函数调用
f= open('write.txt',encoding="utf8",mode='w')
#文件写入
f.write('少女的腿毛2\n')
打开文件后,少女的腿毛变成了少女的腿毛2,文件前面写入的内容被完全覆盖。出现这种现象的原因是文件写入模式,那么有哪些模式呢?
文件模式
常用的模式
1、r模式:只读模式
2、w模式:写入模式,这种模式会覆盖之前写入的内容
3、a模式:追加模式,相当于w模式的进阶,区别在于不会覆盖文件已经写入的内容
4、rb模式:用于读取二进制文件的只读,例如图片和视频等
5、wb模式:以二进制文件的写入
6、ab模式:以二进制形式追加写入内容。
详情可见https://www.runoob.com/python/python-func-open.html
write()
3、文件关闭
close()
关闭已经打开的文件。文件打开后需要关闭文件,不然会造成资源被大量占用,导致内存不够。
二、with open()
为解决用户在open()函数调用后忘记关闭文件而导致资源浪费的现象,python提出了with open的用法。语法如下:
#open函数调用
with open('write.txt',encoding="utf8",mode='w') as f:
#文件写入
f.write('tuimao')
其他的用法与open函数一致。不需要用户关闭文件,with open会自动释放缓存。
三、路径处理
1、系统路径,python能够自动找到的系统路径。
import sys
print(sys.path)
#运行结果
['E:\\python_workspaces\\python基础语法\\文件和路径处理',
'E:\\python_workspaces\\python基础语法',
'D:\\Python39\\python39.zip',
'D:\\Python39\\DLLs',
'D:\\Python39\\lib',
'D:\\Python39',
'D:\\Python39\\lib\\site-packages']
2、print(__file__)当前python文件的路径
print(__file__)
3、os.path.abspath:绝对路径
import os
print(os.path.abspath('write.txt'))
#运行结果
E:\python_workspaces\python基础语法\文件和路径处理\write.txt
4、os.path.dirname:获取路径目录。dirname()参数是一个路径。
import os
# print(__file__)
psths = os.path.abspath('write.txt')
print(os.path.dirname(psths))
#运行结果
E:\python_workspaces\python基础语法\文件和路径处理
5、os.path.join(a,b):路径拼接,b可以是文件名称,也可以是文件夹
import os
# print(__file__)
psths = os.path.abspath('write.txt')
#在文件和路径处理:E:\python_workspaces\python基础语法\文件和路径处理下创建一个文件write2.txt
write2 = os.path.join(os.path.dirname(psths),"write2.txt")
print(write2)
#open函数调用
with open(write2,encoding="utf8",mode='w') as f:
#文件写入
f.write('tuimao2')
#运行结果
创建了一个名称为“write2.txt”,内容为
tuimao2的文件