设为首页收藏本站
网站公告 | 这是第一条公告
     

 找回密码
 立即注册
缓存时间02 现在时间02 缓存数据 曾经在《火星情报局》 汪涵问粉丝们“你们会喜欢薛之谦多久”粉丝们都大喊“一辈子” 当时的薛之谦就笑着说“你们骗人”结果,你们真的骗人。

曾经在《火星情报局》 汪涵问粉丝们“你们会喜欢薛之谦多久”粉丝们都大喊“一辈子” 当时的薛之谦就笑着说“你们骗人”结果,你们真的骗人。 -- 我好像在哪见过你

查看: 413|回复: 0

Python实现读取文件的方法总结

[复制链接]

  离线 

TA的专栏

  • 打卡等级:热心大叔
  • 打卡总天数:204
  • 打卡月天数:0
  • 打卡总奖励:3291
  • 最近打卡:2023-08-27 07:22:33
等级头衔

等級:晓枫资讯-上等兵

在线时间
0 小时

积分成就
威望
0
贡献
427
主题
403
精华
0
金钱
4546
积分
854
注册时间
2022-12-24
最后登录
2025-6-1

发表于 2023-2-10 22:48:34 | 显示全部楼层 |阅读模式
序言

哈喽兄弟们,今天咱们来了解一下 fileinput 。
说到fileinput,可能90%的码农表示没用过,甚至没有听说过。
这不奇怪,因为在python界,既然open可以走天下,何必要fileinput呢?
但是,今天我还是要介绍fileinput这个方法,因为太奈斯了。
不止是香。是真香!
接下来,就跟着我,一起fileinput,对,就是这个feel。

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、 默认读取

代码示例
  1. import fileinput

  2. '当 Python 脚本没有传入任何参数时,fileinput 默认会以 stdin 作为输入源'
  3. for line in fileinput.input():
  4.     print(f'{line}')
复制代码
运行结果
234935rjh2li1ticzxaczj.png

你输入的内容,程序都会读取并再输出。
  1. 俗称:复读机
复制代码
3、处理一个文件

代码示例
  1. import fileinput

  2. 'files 输入打开文件的名称即可'
  3. with fileinput.input(files=('output.txt',)) as file:
  4.     for line in file:
  5.         print(f'{fileinput.filename()} 第{fileinput.lineno()}行:{line}',end='')
复制代码
运行结果
234935ynk45d9ckhsn2s4s.png

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

4、处理批量文件

多文件序号连续排序
调用方法
fileinput.lineno()方法
代码示例
  1. import fileinput

  2. 'files 输入打开文件的名称即可'
  3. with fileinput.input(files=('output.txt','input.txt')) as file:
  4.     for line in file:
  5.         #fileinput.lineno() 把两个文件的整合陈一个文件对象file,需要排序输出
  6.         print(f'{fileinput.filename()} 第{fileinput.lineno()}行: {line}', end='')
  7.         
  8.         # fileinput.filelineno()两个文件单独读取,需要单独排序
  9.         print(f'{fileinput.filename()} 第{fileinput.filelineno()}行: {line}', end='')
复制代码
运行结果
234935l0z7qutidnh014da.png

多文件序号单独排序
调用方法
fileinput.filelineno()方法
代码示例
  1. import fileinput

  2. 'files 输入打开文件的名称即可'
  3. with fileinput.input(files=('test1.txt','test2.txt')) as file:
  4.     for line in file:      
  5.         # fileinput.filelineno()两个文件单独读取,需要单独排序
  6.         print(f'{fileinput.filename()} 第{fileinput.filelineno()}行: {line}', end='')
复制代码
运行结果
234935s4itk5nfd1wk5t41.png

与glob配合用法
在颜值的时代,上面的输出样式,已经无法满足我们的需要了,于是乎,我们就想到了glob。
代码示例
  1. import fileinput
  2. import glob

  3. #glob 匹配te开头的txt文件
  4. for line in fileinput.input(glob.glob("te*.txt")):
  5.     if fileinput.isfirstline():
  6.         #输出读取文件
  7.         print('='*10,f'读取文件{fileinput.filename()}','='*10)
  8.         #fileinput.filelineno()方法读取
  9.     print(str(fileinput.filelineno())+ ':'+line.upper(),end='')
复制代码
运行结果
234936zyl04yczgdugwgiu.png

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

5、读取与备份

调用方法
fileinput.input 的backup 参数,可以指定备份的后缀名,比如 .bak
代码示例
  1. import fileinput

  2. #触发backup的动作,源文件内容被修改,对源文件进行backup
  3. with fileinput.input(files=("test1.txt",), backup=".bak",inplace=1) as file:
  4.     for line in file:
  5.         print(line.rstrip().replace('111111', '222222'))
  6.         print(f'{fileinput.filename()} 第{fileinput.lineno()}行: {line}', end='')
复制代码
运行结果
234936bq8ffsooxoko39v9.png


6、重定向替换

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

  2. #触发backup的动作,源文件内容被修改,对源文件进行backup
  3. with fileinput.input(files=("test2.txt",), inplace=True) as file:
  4.     print("[INFO] task is started...")
  5.     for line in file:
  6.         print(f'{fileinput.filename()} 第{fileinput.lineno()}行: {line}', end='')
  7.     print("[INFO] task is closed...")
复制代码
运行结果
234936hz25ze11oe2u2423.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 去读取它;
  1. def online_open(url, mode):
  2.     import requests
  3.     r = requests.get(url)
  4.     filename = url.split("/")[-1]
  5.     with open(filename,'w') as f1:
  6.         f1.write(r.content.decode("utf-8"))
  7.     f2 = open(filename,'r')
  8.     return f2
复制代码
直接将这个函数传给 openhook 即可:
  1. # -*- coding:utf-8 -*-
  2. # @Time   : 2022-07-23
  3. # @Author : carl_DJ

  4. import fileinput
  5. file_url = 'https://www.csdn.net/robots.txt'
  6. with fileinput.input(files=(file_url,), openhook=online_open) as file:
  7.     for line in file:
  8.         print(line, end="")
复制代码
代码整合:
  1. # -*- coding:utf-8 -*-
  2. # @Time   : 2022-07-23
  3. # @Author : carl_DJ
  4. def online_open(url, mode):
  5.     import requests
  6.     r = requests.get(url)
  7.     filename = url.split("/")[-1]
  8.     with open(filename,'w') as f1:
  9.         f1.write(r.content.decode("utf-8"))
  10.     f2 = open(filename,'r')
  11.     return f2

  12. import fileinput
  13. file_url = 'https://www.csdn.net/robots.txt'
  14. with fileinput.input(files=(file_url,), openhook=online_open) as file:
  15.     for line in file:
  16.         print(line, end="")
复制代码
运行结果
234936ajw5to1sjzowowwb.png


总结

关于fileinput的介绍,也就介绍到这里。
fileinput本身是对 open 函数的再次封装,所以在读取的cc部分,就比open显得更专业,更优雅,这也是仅限于读取的方面。
在写的方面,相对于open,就不是那么的强悍。
归根结底,fileinput还是一个不错的方法。值得你拥有。
到此这篇关于Python实现读取文件的方法总结的文章就介绍到这了,更多相关Python读取文件内容请搜索晓枫资讯以前的文章或继续浏览下面的相关文章希望大家以后多多支持晓枫资讯!

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
晓枫资讯-科技资讯社区-免责声明
免责声明:以上内容为本网站转自其它媒体,相关信息仅为传递更多信息之目的,不代表本网观点,亦不代表本网站赞同其观点或证实其内容的真实性。
      1、注册用户在本社区发表、转载的任何作品仅代表其个人观点,不代表本社区认同其观点。
      2、管理员及版主有权在不事先通知或不经作者准许的情况下删除其在本社区所发表的文章。
      3、本社区的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,举报反馈:点击这里给我发消息进行删除处理。
      4、本社区一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
      5、以上声明内容的最终解释权归《晓枫资讯-科技资讯社区》所有。
http://bbs.yzwlo.com 晓枫资讯--游戏IT新闻资讯~~~
严禁发布广告,淫秽、色情、赌博、暴力、凶杀、恐怖、间谍及其他违反国家法律法规的内容。!晓枫资讯-社区
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|晓枫资讯--科技资讯社区 本站已运行

CopyRight © 2022-2025 晓枫资讯--科技资讯社区 ( BBS.yzwlo.com ) . All Rights Reserved .

晓枫资讯--科技资讯社区

本站内容由用户自主分享和转载自互联网,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。

如有侵权、违反国家法律政策行为,请联系我们,我们会第一时间及时清除和处理! 举报反馈邮箱:点击这里给我发消息

Powered by Discuz! X3.5

快速回复 返回顶部 返回列表