嗨害大家好鸭! 我是小熊猫❤

咱今天来了解一下 fileinput

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

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

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

不止是香。是真香!

接下来,就跟着我,一起fileinput~ ~~

对,就是这个feel。


有什么python相关报错解答自己不会的、或者源码资料/模块安装/女装大佬精通技巧 都可以来这里:(https://jq.qq.com/?_wv=1027&k=2Q3YTfym)或者+V:python10010问我

一、方法介绍

基本用法

先来看一下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():关闭序列。

二、 默认读取

代码示例

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

运行结果


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

俗称:复读机

三、处理一个文件

代码示例

import fileinput'files 输入打开文件的名称即可'
with fileinput.input(files=('output.txt',)) as file:for line in file:print(f'{fileinput.filename()} 第{fileinput.lineno()}行:{line}',end='')

运行结果


解析:

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

四、处理批量文件

多文件序号连续排序

调用方法

  • fileinput.lineno()方法

代码示例

import fileinput'files 输入打开文件的名称即可'
with fileinput.input(files=('output.txt','input.txt')) as file:for line in file:#fileinput.lineno() 把两个文件的整合陈一个文件对象file,需要排序输出print(f'{fileinput.filename()} 第{fileinput.lineno()}行: {line}', end='')# fileinput.filelineno()两个文件单独读取,需要单独排序print(f'{fileinput.filename()} 第{fileinput.filelineno()}行: {line}', end='')

运行结果


多文件序号单独排序

调用方法

  • fileinput.filelineno()方法

代码示例

import fileinput'files 输入打开文件的名称即可'
with fileinput.input(files=('test1.txt','test2.txt')) as file:for line in file:       # fileinput.filelineno()两个文件单独读取,需要单独排序print(f'{fileinput.filename()} 第{fileinput.filelineno()}行: {line}', end='')

运行结果

与glob配合用法

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

代码示例

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

运行结果


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

五、读取与备份

调用方法

fileinput.input 的backup 参数,可以指定备份的后缀名,比如 .bak

代码示例

import fileinput#触发backup的动作,源文件内容被修改,对源文件进行backup
with fileinput.input(files=("test1.txt",), backup=".bak",inplace=1) as file:for line in file:print(line.rstrip().replace('111111', '222222'))print(f'{fileinput.filename()} 第{fileinput.lineno()}行: {line}', end='')

运行结果

六、重定向替换

解析

上面的例子, 用到了 inplace参数,表示是否将标准输出的结果写回文件,默认不取代。
代码示例:

import fileinput#触发backup的动作,源文件内容被修改,对源文件进行backup
with fileinput.input(files=("test2.txt",), inplace=True) as file:print("[INFO] task is started...")for line in file:print(f'{fileinput.filename()} 第{fileinput.lineno()}行: {line}', end='')print("[INFO] task is closed...")

运行结果

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

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

七、进阶

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 去读取它;
def online_open(url, mode):import requestsr = requests.get(url) filename = url.split("/")[-1]with open(filename,'w') as f1:f1.write(r.content.decode("utf-8"))f2 = open(filename,'r')return f2

直接将这个函数传给 openhook 即可:

# -*- coding:utf-8 -*-
# @Time   : 2022-07-23
# @Author : carl_DJimport fileinput
file_url = 'https://www.csdn.net/robots.txt'
with fileinput.input(files=(file_url,), openhook=online_open) as file:for line in file:print(line, end="")

代码整合:

# -*- coding:utf-8 -*-
# @Time   : 2022-07-23
# @Author : carl_DJ
def online_open(url, mode):import requestsr = requests.get(url)filename = url.split("/")[-1]with open(filename,'w') as f1:f1.write(r.content.decode("utf-8"))f2 = open(filename,'r')return f2import fileinput
file_url = 'https://www.csdn.net/robots.txt'
with fileinput.input(files=(file_url,), openhook=online_open) as file:for line in file:print(line, end="")

运行结果


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

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

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


今天的文章就分享到这里啦~

有啥不懂,大胆问~

我是小熊猫,咱下篇文章再见啦(✿◡‿◡)

天花板级别的python读取文件方法,真的香.......相关推荐

  1. 超全Python读取文件方法,不容错过噢!

    大家好, 文件是无处不在的,无论我们使用哪种编程语言,处理文件对于每个程序员都是必不可少的 文件处理是一种用于创建文件.写入数据和从中读取数据的过程,Python 拥有丰富的用于处理不同文件类型的包, ...

  2. python读取文件第n行-Python读取文件最后n行的方法

    本文实例讲述了Python实现读取文件最后n行的方法.分享给大家供大家参考,具体如下: # -*- coding:utf8-*- import os import time import dateti ...

  3. python怎么读文件内容-Python读取文件内容为字符串的方法(多种方法详解)

    以下笔记是我在 xue.cn 学习群之数据分析小组所整理分享的心得.相关背景是:我选择中文词频统计案例作为考察大家python基础功掌握程度. 以小见大,下面是2个小技能的具体实战: 如何灵活地处理文 ...

  4. python numpy读取数据_大神教你python 读取文件并把矩阵转成numpy的两种方法

    导读 今天小编就为大家分享一篇python 读取文件并把矩阵转成numpy的两种方法,具有很好的参考价值,希望对大家有所帮助.一起跟随小编过来看看吧 在当前目录下: 方法1: file = open( ...

  5. Python读取文件中汉字方法:导入codecs,添加encoding='utf-8'

    通过文件路径读取文件时候,要么用左侧斜杠,要么用两个右侧斜杠 Python读取文件中的汉字方法:导入codecs,添加encoding='utf-8'import codecs a = open('D ...

  6. python大神读取_大神教你python 读取文件并把矩阵转成numpy的两种方法

    导读 今天小编就为大家分享一篇python 读取文件并把矩阵转成numpy的两种方法,具有很好的参考价值,希望对大家有所帮助.一起跟随小编过来看看吧 在当前目录下: 方法1: file = open( ...

  7. Python读取文件编码及内容

    Python读取文件编码及内容 最近做一个项目,需要读取文件内容,但是文件的编码方式有可能都不一样.有的使用GBK,有的使用UTF8.所以在不正确读取的时候会出现如下错误: UnicodeDecode ...

  8. python读取文件第n行-python读取文件第n行

    广告关闭 2017年12月,云+社区对外发布,从最开始的技术博客到现在拥有多个社区产品.未来,我们一起乘风破浪,创造无限可能. pos = pos - 1 try: f.seek(pos, 2) #从 ...

  9. python读取文件第n行-Python读取文件后n行的代码示例

    这篇文章主要介绍了Python实现读取文件最后n行的方法,涉及Python针对文件的读取.遍历与运算相关操作技巧,需要的朋友可以参考下# -*- coding:utf8-*- import os im ...

最新文章

  1. jquery上传图片
  2. 【网易中台实践】云信业务中台的敏捷开发
  3. k8s容器生命周期:指定启动、退出动作
  4. adb: createprocessw failed: 系统找不到指定的路径_gcc编译过程、gcc命令参数、静态库和动态库搜索路径...
  5. Oracle代码块详解,Oracle可执行代码块
  6. 织梦mysql安装教程视频教程_织梦DedeCMSV6系统安装步骤教程
  7. abd.exe 需要下java吗_Abd.exe文件下载|
  8. lt;a href=quot;javascript:history.back();quot;gt;返回上一页lt;/agt;
  9. NullPointerException空指针异常的理解
  10. 手把手教你架构3D游戏引擎
  11. 许可证加密的WMV文件破解
  12. Jenkins报错'Gradle build daemon disappeared unexpectedly'的问题解决
  13. 阿里员工爆出最好用的python库推荐!!--random随机数生成【原文附代码】
  14. 什么是自然语言处理(NLP)?定义+应用一次性看个明白
  15. HTML制作3D樱花漫天飞舞及浪漫信封
  16. 学界 | 大数据背景下,景观研究怎么做?
  17. AtCoder2362 - Splatter Painting - DFS+思维
  18. python面试自我介绍_我的python面试简历
  19. 选购摄像头前必看,摄像头参数科普
  20. 计算机视觉OpenCV(五):图像金字塔与轮廓检测

热门文章

  1. 让离线程序也需要输入校验码(激活码)才可使用(python实现)
  2. C语言——操作符详解
  3. 电脑重命名文件会卡住很久的解决办法
  4. 画家百度百科创建应该怎么做呢?
  5. 双十一屡“爆表” 经受考验的不再是电商是AI技术
  6. LInux软硬链接概念,03硬链接和软链接的区别和联系
  7. C语言基础教程 之 字符型:char
  8. 北京时间换算国际时间
  9. 写作课笔记(0902更新)
  10. C语言 单精度和双精度实数输出