python读取文件中的内容并输出_Python怎么把文件内容读取出来,怎么把内容写入文件中...

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

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

u=3540879545,3517169037&fm=173&app=49&f=JPEG?w=640&h=360&s=F908AF57DF9159C250E7B96003007078

完整的语法格式为:

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

参数说明:

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

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

u=3377372429,1636530635&fm=173&app=49&f=JPEG?w=640&h=52

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

u=3824435744,756601627&fm=173&app=49&f=JPEG?w=347&h=144&s=A0C2B5441FA0BF600658381D0000E0C0

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

u=2100994673,2480279705&fm=173&app=49&f=JPEG?w=457&h=261&s=E2D235C006B0A66D544CC40A0000F0C2

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

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

u=2359805300,2259130099&fm=173&app=49&f=JPEG?w=503&h=290&s=A2D235C452F4B66B18CDE50E000070C2

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

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

u=3130008174,3183330044&fm=173&app=49&f=JPEG?w=513&h=360&s=E2D235C05AF6B64F0A49940C0000E0C0

读取文件怎么操作内容

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

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

u=3510507096,2508664546&fm=173&app=49&f=JPEG?w=456&h=273&s=E2D235C05BE4B6490ED1050E000070C0

输出结果

u=3468505113,3512994458&fm=173&app=49&f=JPEG?w=370&h=294&s=E8C2934142F6B66D5EE1400B0000E0C3

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

文件的内容一部分

u=4141150036,3466529522&fm=173&app=49&f=JPEG?w=414&h=383&s=F2F231C052E6874D44CD750F0000E0C1

read(size)

u=69235030,447876001&fm=173&app=49&f=JPEG?w=466&h=259&s=E0D031C053F496691EC5150D0000E0C1

输出结果

u=1259043319,3068175787&fm=173&app=49&f=JPEG?w=279&h=247&s=A8C2934142F6B66D1E51440F0000E0C3

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

u=2250793522,1530156240&fm=173&app=49&f=JPEG?w=474&h=283&s=E2D031C01AE4BE4D1EC0150F0000E0C0

输出结果:空行也算一行

u=2560298833,3797435958&fm=173&app=49&f=JPEG?w=296&h=185&s=A8C293416FA497681E71B40E000070C3

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

u=953205789,3136463100&fm=173&app=49&f=JPEG?w=466&h=244&s=E2D031C413F0BE681ED0250F0000E0C0

输出结果

u=2123177267,1028085133&fm=173&app=49&f=JPEG?w=627&h=244&s=A0C2B5419EA0A9720C5C1C0F0000C0C2

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

u=817478114,1920514366&fm=173&app=49&f=JPEG?w=473&h=271&s=F2C0B1445BF486491EC1050F0000E0C0

既然是列表就可以用切片

u=132357187,2401909617&fm=173&app=49&f=JPEG?w=470&h=278&s=E0F031C45BE486490EC1250F0000F0C2

写文件

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

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

区别就是:

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

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

u=1690092214,3950937722&fm=173&app=49&f=JPEG?w=509&h=113&s=E2F031C0C9CDBF700654480C000070C0

u=2005383855,1642534566&fm=173&app=49&f=JPEG?w=225&h=83&s=E2B233C09DC139700CE895010100A0C3

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

u=239768850,3362025390&fm=173&app=49&f=JPEG?w=505&h=116&s=E2F031C4DDCD8970047C4D01000070C0

u=3662316491,2089200451&fm=173&app=49&f=JPEG?w=224&h=96&s=F2F235C017F1B86158F995010100E0C3

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

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

u=1088768258,925825889&fm=173&app=49&f=JPEG?w=513&h=101&s=FAD031C4CDCE0F7244544C090200B0C0

u=2323776976,1806466140&fm=173&app=49&f=JPEG?w=245&h=88&s=E2E2B340118139704CF895010100A0C3

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

u=4167511448,12511641&fm=173&app=49&f=JPEG?w=504&h=104&s=EAF031C0CD87377006540D0C0200F0C2

u=1848875888,208387108&fm=173&app=49&f=JPEG?w=237&h=117&s=E2F231C057A1B94942F895010100E0C3

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

u=3991836790,3790490528&fm=173&app=49&f=JPEG?w=547&h=110&s=EA9031C0EFA7AF70045408070000A0C0

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

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

u=3386721209,616910982&fm=173&app=49&f=JPEG?w=610&h=122&s=FAD021C46FA7BB70165C4C13000070C0

mode模式主要几种:

+:打开一个文件进行更新(可读可写)。r:以只读方式打开文件。默认模式b:二进制格式打开w:打开一个文件只用于写入。a:打开一个文件用于追加。需要二进制就后面rb、wb、ab,其实加号(r+、w+、a+)我试了跟没加效果没有多大区别。总之可以组合。

写一个index.html

u=543048319,1880178925&fm=173&app=49&f=JPEG?w=635&h=643&s=E2D235C4D2B6966D4A418C0E0000E0C3

生成文件中的html代码

u=134577339,2486660165&fm=173&app=49&f=JPEG?w=414&h=372&s=E0D235C012E6874F1C51E00E0000F0C3

浏览器效果

u=2225022397,2692636140&fm=173&app=49&f=JPEG?w=391&h=187&s=8D18ED120B4A4C491AF4E5D30000C0B3

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

  • 4
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值