当前位置: 首页 > news >正文

【python学习】文件操作

文件操作

  • 打开文件
    • read()函数
    • readlines()函数
    • readline()函数
    • for循环读取文件
    • with open读取文件
    • write()写入文件
  • 实践操作

打开文件

在python中,可以用open()打开或者新建一个文件,用法如下:

open('文件名',打开文件模式,编码格式(一般使用“UTF-8”))

read()函数

现在我在桌面新建了一个文本,用文件操作打开并读取,代码如下:

f=open(“D:/桌面/test.txt”,"r",encoding="UTF-8"print(f.read())

运行结果如下:
在这里插入图片描述
这段代码中,“D:/桌面/test.txt”为文本的路径和名称,open函数按照这个路径找到文本打开,“r”是表示只读模式,只读取文本内容,最后是编码,读取完成后返回一个文件,定义f来接受
在输出过程当中,可以用f.read()来读取文件当中的所有内容,当然f.read()括号中也可以传入参数,如下:

f=open("D:/桌面/test.txt","r",encoding="UTF-8")
print(f.read(5))

这里传入参数为5,表示只读取文件当中的前五个字节,所以输出如下:
在这里插入图片描述

readlines()函数

readlines()函数是读取文件的所有行,代码运行如下:

f=open("D:/桌面/test.txt","r",encoding="UTF-8")
print(f.readlines())

在这里插入图片描述
由运行结果可以看出,输出的是一个列表,是因为readlines()函数将文本内容读取为列表,每一行变成列表的一个元素

readline()函数

readline()表示读取该文件中的一行,运行如下:

f=open("D:/桌面/test.txt","r",encoding="UTF-8")
print(f.readline())

在这里插入图片描述
如图所示,文件只读取了一行

for循环读取文件

除上面的函数外,可以直接用for循环来读取文件。代码如下:

f=open("D:/桌面/test.txt","r",encoding="UTF-8")
for line in f:print(line)

输出如下:
在这里插入图片描述
刚开始我还不太理解为什么for line in f,这样怎么读取,但是换一种形式,就好理解得多:

for line in open("D:/桌面/test.txt","r",encoding="UTF-8"):print(line)

这样就很容易理解这个逻辑了,就是在读取这个该文件,line表示读取的每一行

with open读取文件

一般情况下,打开文件读取完成后需要关闭文件流,否则文件会一直被python程序占用,即采用f.close()方式
为避免遗漏关闭文件流,可以采用with open的方式:

with open("D:/桌面/test.txt","r",encoding="UTF-8") as f:print(f.readlines())

这样在读取完成后,会自动关闭文件流,避免遗忘

write()写入文件

类比读取文件,就可得出,写入文件的代码:

f=open("D:/桌面/test.txt","w",encoding="UTF-8")
f.write('hello world')
f.flush()

在这里"w"表示写入模式,调取write()函数来进行写入‘hello world’,查看现在文档内容:
在这里插入图片描述
write写入时,会将文件内的内容清空,再将传入的字符串写入
直接调用write时,内容并未真正写入,而是存入缓冲区
调取flush,内容才算真正写入

如果打开文件的路径中不存在这个文件,将新建文件进行写入

在写入模式中,每次写入都会把文件清空,如果想直接在文件后加入内容,则需要采用添加模式,代码如下:

f=open("D:/桌面/test.txt","a",encoding="UTF-8")
f.write('hello world')
f.flush()

运行结果如图:
在这里插入图片描述
这次写入不把文件清空,而是直接在原文件后加入要写入的内容
添加模式中,如果不存在该文件,也会新建文件

实践操作

【实践一】读取test,txt文件,统计当中itheima出现的次数
方法一:

f=open("D:/桌面/test.txt","r",encoding="UTF-8")
print(f.read().count('itheima'))
f.close()

这里读取文件,读取出来是一个字符串,就相当于f.read()是一个字符串,这是最简单的一种方法,直接使用“字符串.count(‘统计内容’)”来统计这个字符串在文本当中出现的次数
方法二:

f=open("D:/桌面/test.txt","r",encoding="UTF-8")
count=0
for line in f:line=line.strip()words=line.split(" ")for  str in words:if str=="itheima":count+=1
print(count)f.close()

在这里,对因为不同字符串之间都是空格范围内开的,所以想着把每一行以空格为间隔分割成一个列表,每个字符串为一个元素
这里 line=line.strip()是将每行最后的换行符去掉
words=line.split(" ")是将每行分割成列表
再循环列表,如果有目标字符串,数量就加一

http://www.dtcms.com/a/483579.html

相关文章:

  • 安卓上怎么做单机网站什么网站可以做英语题
  • 营销型网站上海制作简约网站首页
  • 【详细证明 | 题解】洛谷 P2508 [HAOI2008] 圆上的整点 [数学]
  • 化州市建设局网站淘宝联盟怎么建设网站
  • 为什么函数会被变量“覆盖”?三大语言命名机制解析
  • 第一个 Vue 程序:从入门到实战笔记(初学者专属)
  • 常见网站安全攻击手段及防御方法
  • 4.Windows Server 磁盘管理
  • 从告警风暴到根因定位:SigNoz+CPolar让分布式系统观测效率提升10倍的实战指南
  • 互联网站安全网站的建站方案
  • 分布式事务:本地消息表原理与实现详解
  • sns社交网站有哪些焦作网站开发
  • Python全栈(基础篇)——Day11:函数进阶(高阶函数+作用域+匿名函数+实战演示+每日一题)
  • SQL语句为什么要避免使用join
  • MATLAB学习文档(二十四)
  • 【卷积神经网络CNN】基本原理
  • Jenkins Share Library教程 —— 高级实战与最佳实践
  • 基于DNA编码与混沌系统的图像加密
  • 网站建设中的html网站页面设计图片素材
  • 【数据库】MySQL InnoDB Cluster 高可用架构部署(MGR 3节点)
  • 网站关键词选取网站开发使用软件有哪些
  • 网站建设 鼠标定制化网站开发公司
  • WebUI自动化测试:POM设计模式全解析
  • tauri 应用相关文件夹
  • 建设网站哪家便宜南昌网站排名
  • AI赋能,重塑未来招聘:深度解析易路AI人岗匹配解决方案
  • 四川网站建设的公司哪家好苏州网站建设熊掌
  • QT6中Dial、Key Sequence Edit、LCD Number 功能及用法详解
  • 为什么要创建网站公司网站建设管理
  • Tomcat核心架构与生产部署指南