文章目录
1. 文件的编码
编码就是一种规则集合,记录了内容和二进制间进行相互转换的逻辑。
编码有许多中,我们最常用的是UTF-8编码
计算机只认识0和1,所以需要将内容翻译成0和1才能保存在计算机中。
同时也需要编码, 将计算机保存的0和1,反向翻译回可以识别的内容。
2. 文件的读取
在日常生活中,文件操作主要包括打开、关闭、读、写等操作。
想想我们平常对文件的基本操作,大概可以分为三个步骤(简称文件操作三步走):
① 打开文件
② 读写文件
③ 关闭文件
注意:可以只打开和关闭文件,不进行任何读写
2.1 open()打开函数
语法:
open(name,mode,encoding)
# name:是要打开的目标文件名的字符串(可以包含文件所在的具体路径)。
# mode:设置打开文件的模式(访问模式):只读、写入、追加等。
# encoding:编码格式(推荐使用UTF-8)
eg
# 只读文件python.txt
f = open('python.txt', 'r', encoding=”UTF-8)
注意:此时的
f是
open函数的文件对象,对象是Python中一种特殊的数据类型,拥有属性和方法,可以使用对象.属性或对象.方法对其进行访问
2.2 mode常用的三种
模式 | 描述 |
---|---|
r | 以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。 |
w | 打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,原有内容会被删除。如果该文件不存在,创建新文件。 |
a | 打开一个文件用于追加。如果该文件已存在,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。 |
2.3 读操作相关方法
read()方法:
文件对象.reand(nun)
num表示要从文件中读取的数据的长度,如果没有传入num,那么就表示读取文件中所有的数据。
readlines()方法:
readlines可以按照行的方式把整个文件中的内容进行一次性读取,并且返回的是一个列表,其中每一行的数据为一个元素。
f = open('文件名')
content = f.readlines()
print(content)
# 关闭文件
f.close()
readline()方法:一次读取一行内容
f = open('文件名')
content = f.readline()
print(f'第一行:{content}')
content = f.readline()
print(f'第二行:{content}')
# 关闭文件
f.close()
for循环读取文件行
for line in open("文件名", "模式"):
print(line)
# 每一个line临时变量,就记录了文件的一行数据
close() 关闭文件对象
f.close()
最后通过close,关闭文件对象,也就是关闭对文件的占用
如果不调用close,同时程序没有停止运行,那么这个文件将一直被Python程序占用。
with open 语法
with open("文件名", "模式") as f:
f.readlines()
# 通过在with open的语句块中对文件进行操作
# 可以在操作完成后自动关闭close文件,避免遗忘掉close方法
2.3.1 操作汇总
操作 | 功能 |
---|---|
文件对象 = open(file, mode, encoding) | 打开文件获得文件对象 |
文件对象.read(num) | 读取指定长度字节不指定num读取文件全部 |
文件对象.readline() | 读取一行 |
文件对象.readlines() | 读取全部行,得到列表 |
for line in 文件对象 | for循环文件行,一次循环得到一行数据 |
文件对象.close() | 关闭文件对象 |
with open() as f | 通过with open语法打开文件,可以自动关闭 |
2.3.2 案例
通过Windows的文本编辑器软件,将如下内容,复制并保存到:word.txt,文件可以存储在任意位置
人生的道路是漫长的,如果你只会一味的感伤失去,那么你将一无所有,只有有能力去享受失去的乐趣的人,才能真正品尝到人生的幸福。
让自己承受失去的东西,也许你会感到很痛苦,那也要自己去承受,别人是代替不了你的。
伤和痛是有的,这就证明你已经长大了,成熟了。
失去的时候,你可以哭,可以发泄,可以找朋友倾诉……过后,你的世界就会充满了阳光。
通过文件读取操作,读取此文件,统计‘你’出现的次数
## 案例
with open("路径word.txt", "r", encoding="utf-8") as f:
count = 0
for line in f:
line = line.strip()
for word in line:
if word == "你":
count += 1
print(f"你出现的次数为{count}")
3. 文件的写入
# 1. 打开文件
f = open('文件名', 'w')
# 2.文件写入
f.write('内容')
# 3. 内容刷新
f.flush()
注意: 直接调用write,内容并未真正写入文件,而是会积攒在程序的内存中,称之为缓冲区 当调用flush的时候,内容会真正写入文件 这样做是避免频繁的操作硬盘,导致效率下降(攒一堆,一次性写磁盘)
文件如果不存在,使用”w”模式,会创建新文件
文件如果存在,使用”w”模式,会将原有内容清空
4. 文件的追加
# 1. 打开文件,通过a模式打开即可
f = open('文件名', 'a')
# 2.文件写入
f.write('内容')
# 3. 内容刷新
f.flush()
注意:文件不存在会创建文件,文件存在会在最后,追加写入文件
5. 综合案例
需求:有一份账单文件,记录了消费收入的具体记录,内容如下:
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,消费,正式
读取文件
将文件写出到bill.txt.bak文件作为备份
同时,将文件内标记为测试的数据行丢弃
# 打开文件得到文件对象,准备读取
fr = open("D:/book/study book/python基础/代码/08_文件操作/账单.txt", "r", encoding="utf-8")
# 打开文件得到文件对象,准备写入
fw = open("D:/book/study book/python基础/代码/08_文件操作/bill.txt.bak", "w", encoding="UTF-8")
# for循环读取文件
for line in fr:
line = line.strip()
# 判断内容,将满足的内容写出
if line.split(",")[4] == "测试":
continue # continue进入下一次循环,这一次后面的内容就跳过了
# 将内容写出去
fw.write(line)
# 由于前面对内容进行了strip()的操作,所以要手动的写出换行符
fw.write("\n")
# close2个文件对象
fr.close()
fw.close() # 写出文件调用close()会自动flush()