八、Python文件操作

  1. 文件编码的概念

1.什么是编码?

编码就是一种规则集合,记录了内容和二进制间进行相互转换的逻辑。编码有许多中,我们最常用的是UTF-8编码

2.为什么需要使用编码?

计算机只认识0和1,所以需要将内容翻译成0和1才能保存在计算机中同时也需要编码,将计算机保存的0和1,反向翻译回可以识别的内容

  1. 文件的读取操作

1.操作文件需要通过open函数打开文件得到文件对象

2.文件对象有如下读取方法:

read()

readline()

readlines()

for line in 文件对象

3.文件读取完成后,要使用文件对象.close()方法关闭文件对象,否则文件会被一直占用

文件操作汇总

"""
对文件的读取
"""
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()

  1. 文件的写入

1.写入文件使用open函数的”w“模式进行写入
2.写入的方法有:
  • wirte(),写入内容

  • flush(),刷新内容到硬盘中

3.注意事项
  • 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()

  1. 文件的追加写入操作

1.追加写入文件使用open函数的”a”模式进行写入
2.追加写入的方法有(和w模式一致):
  • wirte(),写入内容

  • flush(),刷新内容到硬盘中

3.注意事项:
  • 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()

  1. 文件操作的综合案例

"""
# 文件操作的综合案例
"""
# 打开文件准备读取
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()
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值