python文件处理fileinput使用方法详解
这篇文章主要介绍了python文件处理fileinput使用方法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
一、介绍
fileinput模块可以对一个或多个文件中的内容进行迭代、遍历等操作,我们常用的open函数是对一个文件进行读写操作。
fileinput模块的input()函数比open函数更高效和好用,体现在:
input()函数生成一个迭代器,保证了在遇到大文件的读取时不会占用太大的内存。
用fileinput对文件进行循环遍历,格式化输出,查找、替换等操作,还能获取每一行的行号等等,非常方便。
二、fileinput读取文件函数input的使用格式
fileinput.input(files='filename',inplace=False,backup='',bufsize=0,mode='r',openhook=None)
files:#文件的路径列表,默认是stdin方式,多文件['1.txt','2.txt',...] inplace:#是否将标准输出的结果写回文件,默认不取代 backup:#备份文件的扩展名,只指定扩展名,如.bak。如果该文件的备份文件已存在,则会自动覆盖。 bufsize:#缓冲区大小,默认为0,如果文件很大,可以修改此参数,一般默认即可 mode:#读写模式,默认为只读 openhook:#该钩子用于控制打开的所有文件,比如说编码方式等;
三、fileinput中的常用函数
函数
描述
input([files[,inplace[,backup]]])
帮助迭代多个输入流中的行
filename()
返回当前文件的名称
lineno()
返回(累计的)当前行号
filelineno()
返回在当前文件中的行号
isfirstline()
检查当前行是否是文件中的第一行
isstdin()
检查最后一行是否来自sys.stdin
nextfile()
关闭当前文件并移到下一个文件
close()
关闭序列
fileinput.input是最重要的函数,它返回一个迭代器对象,如果要处理多个文件,可以向这个函数提供一个或多个文件名。
还可将参数inplace设置为True(inplace=True),对于你访问的每一行,都需打印出替代内容,这些内容将被写回到当前输入文件中,此时可选参数backup用于给从原始文件创建的备份文件指定扩展名。
四、示例
1、读取多个文件
#a.txt文件的内容 """ 我 是 好 人 """ #b.txt文件的内容 """ 他 是 坏 人 """ #读取一个文件 forlineinfileinput.input("a.txt"): print(line) #读取多个文件 forlineinfileinput.input(["a.txt","b.txt"]): print(line)
2、修改文件并备份原文件
#-*_coding:utf-8-*- importfileinput forlineinfileinput.input("a.txt",backup=".bak",inplace=True): line=line.replace("我","小明") print(line) #结果 当前文件夹会生成a.txt.bak文件,内容是之前的内容, 而a.txt文件已经被修改了,把"我"变成了"小明"
3、输出当前行号和行内容
#-*_coding:utf-8-*- importfileinput forlineinfileinput.input("a.txt"): lineno=fileinput.filelineno() printlineno,line #结果 1我 2是 3好、 4人
4、输出文件名
#-*_coding:utf-8-*- importfileinput forlineinfileinput.input("a.txt"): #在第一行前面先输出文件名 iffileinput.isfirstline(): printfileinput.filename() printline #结果 a.txt 我 是 好、 人
其他函数,都是类似的使用方法,这里就不全部介绍了。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。