这个Python读取文件的方法,堪称天花板级别...

简介: Python学习


今天来了解一下 fileinput 。

说到fileinput,可能90%的码农表示没用过,甚至没有听说过。

这不奇怪,因为在python界,既然open可以走天下,何必要fileinput呢?

但是,今天我还是要介绍fileinput这个方法,因为太奈斯了。

不止是香。是真香!

正文

1、方法介绍

基本用法

先来看一下fileinput的基本功能:

fileinput.filename():返回当前被读取的文件名。—>在第一行被读取之前,返回 None。

fileinput.fileno():返回以整数表示的当前文件“文件描述符”。—>当未打开文件时(处在第一行和文件之间),返回 -1。

fileinput.lineno():返回已被读取的累计行号。—>在第一行被读取之前,返回 0。在最后一个文件的最后一行被读取之后,返回该行的行号。

fileinput.filelineno():返回当前文件中的行号。—>在第一行被读取之前,返回 0。—>在最后一个文件的最后一行被读取之后,返回此文件中该行的行号。

进阶用法

fileinput.isfirstline():如果刚读取的行是其所在文件的第一行则返回 True,否则返回 False。

fileinput.isstdin():如果最后读取的行来自 sys.stdin 则返回 True,否则返回 False。

fileinput.nextfile():关闭当前文件以使下次迭代将从下一个文件(如果存在)读取第一行;不是从该文件读取的行将不会被计入累计行数。直到下一个文件的第一行被读取之后文件名才会改变。—>在第一行被读取之前,此函数将不会生效;它不能被用来跳过第一个文件。—>在最后一个文件的最后一行被读取之后,此函数将不再生效。

fileinput.close():关闭序列。

2、 默认读取

代码示例

importfileinput'当 Python 脚本没有传入任何参数时,fileinput 默认会以 stdin 作为输入源'forlineinfileinput.input():
print(f'{line}')

运行结果

image.png

你输入的内容,程序都会读取并再输出。

俗称:复读机

1

3、处理一个文件

代码示例

importfileinput'files 输入打开文件的名称即可'withfileinput.input(files=('output.txt',)) asfile:
forlineinfile:
print(f'{fileinput.filename()}{fileinput.lineno()}行:{line}',end='')

运行结果

image.png

解析:

  • fileinput 有且仅有这两种读取模式:‘r’,‘rb’;
  • fileinput.input() 默认使用 mode=‘r’ 的模式读取文件,如果你的文件是二进制的,可以使用mode=‘rb’ 模式。

4、处理批量文件

多文件序号连续排序

调用方法

  • fileinput.lineno()方法代码示例
importfileinput'files 输入打开文件的名称即可'withfileinput.input(files=('output.txt','input.txt')) asfile:
forlineinfile:
#fileinput.lineno() 把两个文件的整合陈一个文件对象file,需要排序输出print(f'{fileinput.filename()}{fileinput.lineno()}行: {line}', end='')
# fileinput.filelineno()两个文件单独读取,需要单独排序print(f'{fileinput.filename()}{fileinput.filelineno()}行: {line}', end='')

运行结果

image.png

多文件序号单独排序

调用方法

  • fileinput.filelineno()方法代码示例
importfileinput'files 输入打开文件的名称即可'withfileinput.input(files=('test1.txt','test2.txt')) asfile:
forlineinfile:       
# fileinput.filelineno()两个文件单独读取,需要单独排序print(f'{fileinput.filename()}{fileinput.filelineno()}行: {line}', end='')

运行结果

image.png

与glob配合用法

在颜值的时代,上面的输出样式,已经无法满足我们的需要了,于是乎,我们就想到了glob。

代码示例

importfileinputimportglob#glob 匹配te开头的txt文件forlineinfileinput.input(glob.glob("te*.txt")):
iffileinput.isfirstline():
#输出读取文件print('='*10,f'读取文件{fileinput.filename()}','='*10)
#fileinput.filelineno()方法读取print(str(fileinput.filelineno())+':'+line.upper(),end='')

运行结果

image.png

就这颜值,哪个小姐姐能不喜欢呢。

5、读取与备份

调用方法

  • fileinput.input 的backup 参数,可以指定备份的后缀名,比如 .bak代码示例
importfileinput#触发backup的动作,源文件内容被修改,对源文件进行backupwithfileinput.input(files=("test1.txt",), backup=".bak",inplace=1) asfile:
forlineinfile:
print(line.rstrip().replace('111111', '222222'))
print(f'{fileinput.filename()}{fileinput.lineno()}行: {line}', end='')

运行结果

image.png

6、重定向替换

解析

  • 上面的例子, 用到了 inplace参数,表示是否将标准输出的结果写回文件,默认不取代。代码示例:
importfileinput#触发backup的动作,源文件内容被修改,对源文件进行backupwithfileinput.input(files=("test2.txt",), inplace=True) asfile:
print("[INFO] task is started...")
forlineinfile:
print(f'{fileinput.filename()}{fileinput.lineno()}行: {line}', end='')
print("[INFO] task is closed...")

运行结果

image.png

通过运行结果,可以看到:

  • 在 for 循环体内的 print 内容会写回到原文件中了。
  • 而在 for 循环体外的 print 则没有变化。

7、进阶

openhook含义解析

  • 在 fileinput.input() 中有一个 openhook 的参数,它支持用户传入自定义的对象读取方法;
  • 如果没有传入任何勾子,fileinput 默认使用的是 open 函数;方法介绍

fileinput 内置了两种勾子

1、fileinput.hook_compressed(filename, mode)

  • 使用 gzip 和 bz2 模块透明地打开 gzip 和 bzip2 压缩的文件(通过扩展名 ‘.gz’ 和 ‘.bz2’ 来识别);
  • 如果文件扩展名不是 ‘.gz’ 或 ‘.bz2’,文件会以正常方式打开(即使用 open() 并且不带任何解压操作);
  • 使用示例: fi = fileinput.FileInput(openhook=fileinput.hook_compressed)2、fileinput.hook_encoded(encoding, errors=None)
  • 返回一个通过 open() 打开每个文件的钩子,使用给定的 encoding 和 errors 来读取文件。
  • 使用示例: fi = fileinput.FileInput(openhook=fileinput.hook_encoded(“utf-8”, “surrogateescape”))示例实战

假如我想要使用 fileinput 来读取网络上的文件,思路:

  • 先使用 requests 下载文件到本地
  • 再使用 open 去读取它;
defonline_open(url, mode):
importrequestsr=requests.get(url) 
filename=url.split("/")[-1]
withopen(filename,'w') asf1:
f1.write(r.content.decode("utf-8"))
f2=open(filename,'r')
returnf2直接将这个函数传给openhook即可:importfileinputfile_url='https://www.csdn.net/robots.txt'withfileinput.input(files=(file_url,), openhook=online_open) asfile:
forlineinfile:
print(line, end="")
代码整合:defonline_open(url, mode):
importrequestsr=requests.get(url)
filename=url.split("/")[-1]
withopen(filename,'w') asf1:
f1.write(r.content.decode("utf-8"))
f2=open(filename,'r')
returnf2importfileinputfile_url='https://www.csdn.net/robots.txt'withfileinput.input(files=(file_url,), openhook=online_open) asfile:
forlineinfile:
print(line, end="")

运行结果

image.png

总结

关于fileinput的介绍,也就介绍到这里。

fileinput本身是对 open 函数的再次封装,所以在读取的cc部分,就比open显得更专业,更优雅,这也是仅限于读取的方面。在写的方面,相对于open,就不是那么的强悍。

归根结底,fileinput还是一个不错的方法。值得你拥有。

相关文章
|
2月前
|
测试技术 API Python
【10月更文挑战第1天】python知识点100篇系列(13)-几种方法让你的电脑一直在工作
【10月更文挑战第1天】 本文介绍了如何通过Python自动操作鼠标或键盘使电脑保持活跃状态,避免自动息屏。提供了三种方法:1) 使用PyAutoGUI,通过安装pip工具并执行`pip install pyautogui`安装,利用`moveRel()`方法定时移动鼠标;2) 使用Pymouse,通过`pip install pyuserinput`安装,采用`move()`方法移动鼠标绝对位置;3) 使用PyKeyboard,同样需安装pyuserinput,模拟键盘操作。文中推荐使用PyAutoGUI,因其功能丰富且文档详尽。
WK
|
1月前
|
Python
Python中format_map()方法
在Python中,`format_map()`方法用于使用字典格式化字符串。它接受一个字典作为参数,用字典中的键值对替换字符串中的占位符。此方法适用于从字典动态获取值的场景,尤其在处理大量替换值时更为清晰和方便。
WK
70 36
|
2月前
|
安全 Linux 数据安全/隐私保护
python知识点100篇系列(15)-加密python源代码为pyd文件
【10月更文挑战第5天】为了保护Python源码不被查看,可将其编译成二进制文件(Windows下为.pyd,Linux下为.so)。以Python3.8为例,通过Cython工具,先写好Python代码并加入`# cython: language_level=3`指令,安装easycython库后,使用`easycython *.py`命令编译源文件,最终生成.pyd文件供直接导入使用。
python知识点100篇系列(15)-加密python源代码为pyd文件
|
2月前
|
机器学习/深度学习 数据采集 数据挖掘
11种经典时间序列预测方法:理论、Python实现与应用
本文将总结11种经典的时间序列预测方法,并提供它们在Python中的实现示例。
68 2
11种经典时间序列预测方法:理论、Python实现与应用
|
22天前
|
开发者 Python
Python中__init__.py文件的作用
`__init__.py`文件在Python包管理中扮演着重要角色,通过标识目录为包、初始化包、控制导入行为、支持递归包结构以及定义包的命名空间,`__init__.py`文件为组织和管理Python代码提供了强大支持。理解并正确使用 `__init__.py`文件,可以帮助开发者更好地组织代码,提高代码的可维护性和可读性。
22 2
|
2月前
|
Linux 区块链 Python
Python实用记录(十三):python脚本打包exe文件并运行
这篇文章介绍了如何使用PyInstaller将Python脚本打包成可执行文件(exe),并提供了详细的步骤和注意事项。
66 1
Python实用记录(十三):python脚本打包exe文件并运行
|
2月前
|
开发者 Python
Python中的魔法方法与运算符重载
在Python的奇妙世界里,魔法方法(Magic Methods)和运算符重载(Operator Overloading)是两个强大的特性,它们允许开发者以更自然、更直观的方式操作对象。本文将深入探讨这些概念,并通过实例展示如何利用它们来增强代码的可读性和表达力。
|
2月前
|
Java Python
> python知识点100篇系列(19)-使用python下载文件的几种方式
【10月更文挑战第7天】本文介绍了使用Python下载文件的五种方法,包括使用requests、wget、线程池、urllib3和asyncio模块。每种方法适用于不同的场景,如单文件下载、多文件并发下载等,提供了丰富的选择。
|
2月前
|
数据安全/隐私保护 流计算 开发者
python知识点100篇系列(18)-解析m3u8文件的下载视频
【10月更文挑战第6天】m3u8是苹果公司推出的一种视频播放标准,采用UTF-8编码,主要用于记录视频的网络地址。HLS(Http Live Streaming)是苹果公司提出的一种基于HTTP的流媒体传输协议,通过m3u8索引文件按序访问ts文件,实现音视频播放。本文介绍了如何通过浏览器找到m3u8文件,解析m3u8文件获取ts文件地址,下载ts文件并解密(如有必要),最后使用ffmpeg合并ts文件为mp4文件。
|
2月前
|
JSON 数据格式 Python
Python实用记录(十四):python统计某个单词在TXT/JSON文件中出现的次数
这篇文章介绍了一个Python脚本,用于统计TXT或JSON文件中特定单词的出现次数。它包含两个函数,分别处理文本和JSON文件,并通过命令行参数接收文件路径、目标单词和文件格式。文章还提供了代码逻辑的解释和示例用法。
45 0
Python实用记录(十四):python统计某个单词在TXT/JSON文件中出现的次数