编码就是一种规则集合,记录了内容和二进制间进行相互转换的逻辑。编码有许多中,我们最常用的是UTF-8编码
计算机只认识0和1,所以需要将内容翻译成0和1才能保存在计算机中同时也需要编码,将计算机保存的0和1,反向翻译回可以识别的内容
read()
readline()
readlines()
for line in 文件对象
"""
对文件的读取
"""
import time
# 打开文件
f = open("D:\pythonProject2\练习.txt","r", encoding="UTF-8")
print(type(f))
# 读取文件 - read()
print(f"读取10个字节的结果是:{f.read(10)}")
print(f"read方法读取全部内容的结果是:{f.read()}")
# 读取文件 - readlines
lines = f.readlines() # 读取文件的全部行,封装到列表中
print(f"lines对象的类型是:{type(lines)}")
print(f"lines对象的内容是:{lines}")
# 读取文件-readline()
line1 = f.readline()
line2 = f.readline()
line3 = f.readline()
print(f"第一行的内容是:{line1}")
print(f"第二行的内容是:{line2}")
print(f"第三行的内容是:{line3}")
# # for循环读取文件行
for line in f:
print(f"每一行的数据是:{line}")
# 文件的关闭
f.close()
time.sleep(500000)
# with open 语法操作文件
with open("D:\pythonProject2\练习.txt","r", encoding="UTF-8") as f:
print(f"每一行数据是:{line}")
通过Windows的文本编辑器软件,将如下内容,复制并保存到: wordtxt,文件可以存储在任意位置
itheima itcast python
itheima python itcast
beiiing shanghai itheima
shenzhen guangzhou itheima
wuhan hangzhou itheima
zhenazhou biadata itheima
通过文件读取操作,读取此文件,统计itheima单词出现的次数
"""
读取文件,课后练习
"""
# 打开文件,以读取模式打开
f = open("D:\pythonProject2\练习.txt","r",encoding="UTF=8")
# 方式一:读取全部内容,通过字符串count方法统计Itheima单词数量
content = f.read()
count = content.count("itheima")
print(f"itheima在文件中出现了:{count}次")
# 方法二:读取内容,一行一行读取
count = 0 # 使用count变量来累计itheima出现的次数
for line in f:
line = line.strip() # 使用strip将开头结尾的空格和换行符去除
words = line.split(" ") # 使用split将每个元素分隔开
for word in words:
if word == "itheima":
count += 1 # 如果单词是itheima,进行数量的累加加一
# 判断单词出现次数并累计
print(f"itheima出现的次数是:{count}")
# 关闭文件
f.close()
wirte(),写入内容
flush(),刷新内容到硬盘中
w模式,文件不存在,会创建新文件
w模式,文件存在,会清空原有内容
close()方法,带有flush()方法的功能
"""
文件的写入
"""
import time
# 打开文件,不存在的文件,r,w,a
f = open("D:/pythonProject2/练习2.txt","w",encoding="UTF-8")
# write写入
f.write("Hello World!") # 内容写入到内存中
# flush刷新
f.flush() # 将内存中积攒的内容,写入到硬盘的文件中
time.sleep(30000)
# close关闭
f.close() # close方法,内置了flush功能
# # 打开一个存在的文件并写入(新写入的内容会覆盖原文件中的内容)
# f = open("D:/pythonProject2/练习2.txt","w",encoding="UTF-8")
# f.write("python")
# f.close()
wirte(),写入内容
flush(),刷新内容到硬盘中
a模式,文件不存在,会创建新文件
a模式,文件存在,会在原有内容后面继续写入
可以使用”\n”来写出换行符
"""
文件的追加写入
"""
# 打开文件,不存在的文件
f = open("D:/pythonProject2/追加写入.txt","a",encoding="UTF=8")
# write写入
f.write("hei ma cheng xu yuan")
# flush刷新
f.flush()
#close关闭
f.close()
# 打开一个存在的文件,追加内容
f = open("D:/pythonProject2/追加写入.txt","a",encoding="UTF=8")
f.write("\nyue xin guo wan")
f.close()
"""
# 文件操作的综合案例
"""
# 打开文件准备读取
fr = open("D:/pythonProject2/文件操作的综合案例.txt","r",encoding="UTF=8")
# 新建文件准备写入
fw = open("D:/pythonProject2/文件操作的综合案例备份.txt","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")
# close两个文件夹
fr.close()
fw.close()