百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Python怎么把文件内容读取出来,怎么把内容写入文件中

off999 2024-10-02 18:48 14 浏览 0 评论

读写文件是最常见的IO操作。Python内置了读写文件的函数。

Python open() 方法用于打开一个文件,并返回文件对象,在对文件进行处理过程都需要使用到这个函数,如果该文件无法被打开,会抛出 OSError的错误。

完整的语法格式为:

open(file, mode='r', buffering=None, encoding=None, errors=None, newline=None, closefd=True)

参数说明:

  • file: 必需,文件路径(相对或者绝对路径)。
  • mode: 可选,文件打开模式
  • buffering: 设置缓冲
  • encoding: 一般使用utf8
  • errors: 报错级别
  • newline: 区分换行符
  • closefd: 传入的file参数类型

读文件

要以读文件的模式打开一个文件对象,使用Python内置的open()函数,传入文件名和打开模式。读文件的打开模式可以不传,默认就是mode='r'。

./ 当前目录(当前文件);../ 上级目录(上级文件)。

打开模式'r'表示读,这样,我们就成功地打开了一个文件。

如果文件不存在,open()函数就会抛出一个IOError的错误,并且给出错误码和详细的信息告诉你文件不存在。由于我要打开的文件存在,所以不会报错。

还有一个问题如果内容中有中文用f = open(path,'r')去读文件又会报编码错误。所以正确的方法传三个参数最好:传入文件名、打开模式和编码参数。

编码(encoding)推荐utf-8(也可以写成utf8)这样无论中文、英文或者混合的文件都可以读。其中打开模式mode=可以不写,直接参数。因为第一参数文件名必须,打开模式是第二参数,编码是第四参数所以不能省略。


如果要读取图片或者音频文件,打开模式就用'rb',b代表二进制。


读取文件怎么操作内容

  • read():一次性读取文件的全部内容
  • readline():每次读取一行内容
  • readlines():一次读取所有内容并按行返回列表

read()

如果文件很小,read()一次性读取最方便。

输出结果


如果文件有10G,内存就爆了,所以,要保险起见,可以反复调用read(size)方法,每次最多读取size个字节的内容。

文件的内容一部分

read(size)

输出结果


readline()可以每次读取一行内容

输出结果:空行也算一行


readlines():一次读取所有内容并按行返回列表

输出结果

可以用for...in...来循环取内容。

既然是列表就可以用切片


写文件

写文件和读文件是一样的,唯一区别是调用open()函数时,文件打开模式把'r'换成'w'或者'a',表示写文本文件。

无论'w'或者'a',如果该文件不存在,创建新文件。

区别就是:

'w',如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。

第一次写入内容,w.txt文件不存在,自动帮你创建w.txt。

第二次写入内容,w.txt已经存在,就把第一次写入的内容删掉,再把第二次内容写入。


'a',打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。

第一次写入内容,a.txt文件不存在,自动帮你创建a.txt。

第二次写入内容,a.txt已经存在,直接在第一次写入内容的后面把第二次内容写入。


close(),无论是读还是写文件都要打开文件,打开就要关闭文件,要不然一直打开不关闭,内存顶不住。所以打开就要要关闭文件。

每次都这么写实在太繁琐,所以,Python引入了with语句来自动帮我们调用close()方法。注意缩进。

在Python中,文件读写是通过open()函数打开的文件对象完成的。使用with语句操作文件IO是个好习惯。

mode模式主要几种:

  • +:打开一个文件进行更新(可读可写)。
  • r:以只读方式打开文件。默认模式
  • b:二进制格式打开
  • w:打开一个文件只用于写入。
  • a:打开一个文件用于追加。

需要二进制就后面rb、wb、ab,其实加号(r+、w+、a+)我试了跟没加效果没有多大区别。总之可以组合。


写一个index.html

生成文件中的html代码

浏览器效果


读写文件内容的基础差不多就是这么多,往后需要多练、多写来加深记忆。

?

相关推荐

SPC相关的计算用excel和python实现【源码下载】

做SPC分析涉及到很多计算,比如CPK、PPK、概率图、PPM等等,网上很多公式,但具体实现却不是那么容易的。我们整理了这些用excel和python实现的代码。包括但不限于以下的内容:SPC分析中的...

Python学不会来打我(34)python函数爬取百度图片_附源码

随着人工智能和大数据的发展,图像数据的获取变得越来越重要。作为Python初学者,掌握如何从网页中抓取图片并保存到本地是一项非常实用的技能。本文将手把手教你使用Python函数编写一个简单的百度图片...

django python数据中心、客户、机柜、设备资源管理平台源码分享

先转发后关注,私信“资源”即可免费获取源码下载链接!本项目一个开源的倾向于数据中心运营商而开发的,拥有数据中心、客户、机柜、设备、跳线、物品、测试、文档等一些列模块的资源管理平台,解决各类资源集中管理...

熬夜也值得学习练手的108个Python项目(附源码),太实用了!

现在学编程的人越来越多,Python因为简单好上手、功能又强大,成了很多人的首选。不管是做数据分析、人工智能,还是写网络程序、自动化脚本,Python都能派上用场。而且它诞生的时间比网页还早,作为...

这五个办公室常用自动化工具python源码,复制代码就能用

办公室自动化现在能看这文章的恐怕大部分都是办公室久坐工作者,很多都有腰肌劳损、肩周炎等职业病,难道就不能有个工具缓解一下工作量吗?那么恭喜你点进了这篇文章,这篇文章将使用python直接实现五个常...

将python源代码封装成window可执行程序教程

将python源代码封装成window可执行程序教程点击键盘win+r打开运行框在运行框中输入cmd,进入到命令行。在命令行中输入piplist去查看当前电脑中所有的库检查是否有pyinstall...

Python 爬虫如何爬取网页源码?(爬虫获取网页源代码)

下面教大家用几行代码轻松爬取百度首页源码。什么是urllib?urllib库是Python内置的HTTP请求库,它可以看做是处理URL的组件集合。urllib库包含了四大模块,具体如下:urllib....

Python RPC 之 Thrift(python是做什么的)

thrift-0.12.0python3.4.3Thrift简介:Thrift是一款高性能、开源的RPC框架,产自Facebook后贡献给了Apache,Thrift囊括了整个RP...

用Python编写FPGA以太网MAC(附源码下载方式)

来源:EETOP作者:ccpp123略作了解后发现,MyHDL不是高层次综合,它实际上是用Python的一些功能实现了一个Verilog仿真器,能对用Python写的仿Verilog语言进行仿...

python爬虫常用工具库总结(python爬虫工具下载)

说起爬虫,大家可能第一时间想到的是python,今天就简单为大家介绍下pyhton常用的一些库。请求库:实现基础Http操作urllib:python内置基本库,实现了一系列用于操作url的功能。...

手把手教你使用scrapy框架来爬取北京新发地价格行情(理论篇)

来源:Python爬虫与数据挖掘作者:霖hero大家好!我是霖hero。上个月的时候,我写了一篇关于IP代理的文章,手把手教你使用XPath爬取免费代理IP,今天在这里分享我的第二篇文章,希望大家可以...

2025年Python爬虫学习路线:第1阶段 爬虫基础入门开始

这个阶段的目标是让你熟悉Python的基础知识、了解HTTP请求和HTML是如何工作的,并最终完成你的第一个爬虫小项目——抓取名言!按照计划,我们首先要打好Python基础。Python就像是我们要...

如何入门 Python 爬虫?(python零基础爬虫)

1.很多人一上来就要爬虫,其实没有弄明白要用爬虫做什么,最后学完了却用不上。大多数人其实是不需要去学习爬虫的,因为工作所在的公司里有自己的数据库,里面就有数据来帮助你完成业务分析。什么时候要用到爬虫呢...

突破爬虫瓶颈:Python爬虫核心能力提升与案例实操

技术控必看!Python爬虫高手进阶全攻略,解锁数据处理高阶玩法在数字化时代,Python爬虫早已成为数据探索者手中的得力工具。从基础的网页抓取到复杂的数据处理,每一次技术升级都能带来新的突破。本文将...

网络爬虫开源框架(网络爬虫的框架)

目前开源爬虫下载框架是百花齐放,各个编程语言都有,以下主要介绍其中重要的几个:1)python:scrapy,pyspider,gcrawler2)Java:webmagic,WebCollector...

取消回复欢迎 发表评论: