共计 2981 个字符,预计需要花费 8 分钟才能阅读完成。
Python 文件操作
提醒:本文依据 b 站黑马 python 课整顿
链接指引 => 2022 新版黑马程序员 python 教程
一、文件的编码
计算机中有许多可用编码:
- UTF-8
- GBK
- Big5
- 等
UTF-8
是目前全球通用的编码格局
除非有非凡需要,否则,一律以 UTF- 8 格局进行文件编码即可。
二、文件的读取
2.1 open()关上函数
留神:此时的
f
是open
函数的文件对象,对象是 Python 中一种非凡的数据类型,领有属性和办法,能够应用对象. 属性或对象. 办法对其进行拜访,后续面向对象课程会给大家进行具体的介绍。
name:是要关上的指标文件名的字符串(能够蕴含文件所在的具体门路)。mode:设置关上文件的模式(拜访模式):只读、写入、追加等。encoding: 编码格局(举荐应用 UTF-8)open(name, mode, encoding)
例子:
f = open('./test.txt', 'r', encoding='utf-8')
2.2 mode 罕用的三种根底拜访模式
模式 | 形容 |
---|---|
f | 以只读形式关上文件。文件的指针将会放在文件的结尾。这是默认模式。 |
w | 关上一个文件只用于写入。如果该文件已存在则关上文件,并从结尾开始编辑,原有内容会被删除。 如果该文件 不存在,创立新文件 。 |
a | 关上一个文件用于追加。如果该文件已存在,新的内容将会被写入到已有内容之后 。如果该文件 不存在,创立新文件进行写入 。 |
2.3 读操作相干办法
操作汇总
操作 | 性能 |
---|---|
文件对象 = open(file, mode, encoding) | 关上文件取得文件对象 |
文件对象.read(num) | 读取指定长度字节 <br/> 不指定 num 读取文件全副 |
文件对象.readline() | 读取一行 |
文件对象.readlines() | 读取全副行,失去列表 |
for line in 文件对象 | for 循环文件行,一次循环失去一行数据 |
文件对象.close() | 敞开文件对象 |
with open() as f | 通过 with open 语法关上文件,能够主动敞开 |
2.3.1 read()办法:
# num 示意要从文件中读取的数据的长度(单位是字节),如果没有传入 num,那么就示意读取文件中所有的数据。文件对象.read(num)
2.3.2 readlines()办法:
readlines
能够依照行的形式把整个文件中的内容进行一次性读取,并且返回的是一个列表,其中每一行的数据为一个元素。
f = open('python.txt')
content = f.readlines()
# ['hello world\n', 'abcdefg\n', 'aaa\n', 'bbb\n', 'ccc']
print(content)
# 敞开文件
f.close()
例:
readline()办法:一次读取一行内容
f = open('python.txt')
content = f.readline()
print(f'第一行:{content}')
content = f.readline()
print(f'第二行:{content}')
# 敞开文件
f.close()
for 循环读取文件行:
for line in open("python.txt", "r"):
print(line)
# 每一个 line 长期变量,就记录了文件的一行数据
2.3.3 close() 敞开文件对象
f = open("python.txt", "r")
f.close()
# 最初通过 close,敞开文件对象,也就是敞开对文件的占用
# 如果不调用 close, 同时程序没有进行运行,那么这个文件将始终被 Python 程序占用。
2.3.4 with open 语法
with open("python.txt", "r") as f:
f.readlines()
# 通过在 with open 的语句块中对文件进行操作
# 能够在操作实现后主动敞开 close 文件,防止忘记掉 close 办法
案例:通过文件读取操作,读取此文件,统计 itheima 单词呈现的次数
itheima python itcast
beijing shanghai itheima
shenzhen guangzhou itheima
wuhan hangzhou itheima
zhengzhou bigdata itheima
index = 0
with open('./test.txt', 'r', encoding='utf-8') as f:
for line in f:
line = line.strip()
# print(line)
str = line.split(' ')
print(str)
for val in str:
if val == 'it':
index += 1
print(f'index:{index}')
三、文件的写入
3.1 写操作疾速入门
留神:
间接调用 write,内容并未真正写入文件,而是会积攒在程序的内存中,称之为缓冲区
- 当调用 flush 的时候,内容会真正写入文件
- 这样做是防止频繁的操作硬盘,导致效率降落(攒一堆,一次性写磁盘)
文件如果不存在,应用”w”模式,会创立新文件
文件如果存在,应用”w”模式,会将原有内容清空
例:
# 1. 关上文件
f = open('python.txt', 'w')
# 2. 文件写入
f.write('hello world')
# 3. 内容刷新
f.flush()
四、文件的追加
4.1 追加写入操作疾速入门
留神:
- a 模式,文件不存在会创立文件
- a 模式,文件存在会在最初,追加写入文件
案例演示:
# 1. 关上文件,通过 a 模式关上即可
f = open('python.txt', 'a')
# 2. 文件写入
f.write('hello world')
# 3. 内容刷新
f.flush()
五、文件操作综合案例
实现文件备份案例:
bill.txt
name,date,money,type,remarks
周杰轮,2022-01-01,100000, 生产, 正式
周杰轮,2022-01-02,300000, 支出, 正式
周杰轮,2022-01-03,100000, 生产, 测试
林俊节,2022-01-01,300000, 支出, 正式
林俊节,2022-01-02,100000, 生产, 测试
林俊节,2022-01-03,100000, 生产, 正式
林俊节,2022-01-04,100000, 生产, 测试
林俊节,2022-01-05,500000, 支出, 正式
张学油,2022-01-01,100000, 生产, 正式
张学油,2022-01-02,500000, 支出, 正式
张学油,2022-01-03,900000, 支出, 测试
王力鸿,2022-01-01,500000, 生产, 正式
王力鸿,2022-01-02,300000, 生产, 测试
王力鸿,2022-01-03,950000, 支出, 正式
刘德滑,2022-01-01,300000, 生产, 测试
刘德滑,2022-01-02,100000, 生产, 正式
刘德滑,2022-01-03,300000, 生产, 正式
f2 = open('bill.txt.bak', 'a', encoding="utf-8")
with open('bill', 'r', encoding="UTF-8") as f:
for line in f:
line = line.strip()
str = line.split(',')
if str[4] == '测试':
continue
else:
f2.write(f'{line}\n')
f2.close()
总结
以上就是 Python 文件操作,之后会继续更新,欢送大家点赞关注呀~~
正文完