首页 > 编程语言 >这个Python读取文件的方法,堪称天花板级别...

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

时间:2022-09-07 16:56:02浏览次数:91  
标签:... 读取 文件 Python file fileinput print line

前言

嗨喽,大家好呀~这里是爱看美女的茜茜呐

又到了学Python时刻~


今天咱们来了解一下 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、 默认读取

代码示例

import fileinput

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

 

运行结果

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

俗称:复读机

 

3、处理一个文件

代码示例

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’模式。

4、处理批量文件

多文件序号连续排序

调用方法

  • 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='')

 

运行结果

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

5、读取与备份

调用方法

  • 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='')

 

运行结果

6、重定向替换

解析

上面的例子, 用到了 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 则没有变化。

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 去读取它;

def online_open(url, mode):
    import requests
    r = 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_DJ

import 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 requests
    r = 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

import 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="")

 

小伙伴们在学习Python的过程中,有时候不知道怎么学,从哪里开始学。掌握了一些基本的知识或者做了一些案例后,不知道下一步怎么走,不知道如何去学习更加高深的知识。

那么对于这些大兄弟们,我准备了大量的免费视频教程,PDF电子书籍,以及源代码!

==点击 蓝色字体 自取,我都放在这里了。==

还会有大佬解答!

运行结果

总结

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

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

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

希望本篇文章有对你带来帮助

标签:...,读取,文件,Python,file,fileinput,print,line
From: https://www.cnblogs.com/Qqun261823976/p/16666408.html

相关文章

  • python中index()、find()方法
    python中index()、find()方法,具体内容如下:index()方法检测字符串中是否包含子字符串str,该方法与pythonfind()方法一样,只不过如果str不在string中会报一个异常。影响......
  • 【Python】 map() 函数
    map()函数map(function,iterable,...)>>>importmap#计算平方>>>list(map(lambda:x:x**2,[1,2,3,4,5]))#使用lambda匿名函数[1,4,9,16,25]#提供了两个......
  • python3基础语法2
    Python3.0在设计的时候没有考虑向下兼容。官方宣布,2020年1月1日,停止Python2的更新。编码默认情况下,Python3源码文件以 UTF-8 编码,所有字符串都是unico......
  • python中divmod是什么意思?
    python中divmod()是一个内置函数。pythondivmod()函数把除数和余数运算结果结合起来,返回一个包含商和余数的元组(a//b,a%b)。在python2.3版本之前不允许处理复数......
  • Python学习-Day4
    (1)变量的命令规则命名规则:增加代码的识别与可读性定义时=两边留空格每个单词都是用小写,多个单词使用_连接驼峰命名法:小驼峰式命名法:第一个单词的首字母小写,后续单词首......
  • 【Python】math 模块用法
    math模块一些用法trunc(x)传入整数或浮点数,返回数值的整数部分,忽略小数部分,不会四舍五入importmathmath.trunc(2.77)#2math.trunc(8.32)#8math.trunc......
  • React版/Vue版都齐了,开源一套【特别】的后台管理系统...
    本项目主要基于Elux+Antd构建,包含React版本和Vue版本,旨在提供给大家一个简单基础、开箱即用的后台管理系统通用模版,主要包含运行环境、脚手架、代码风格、基本Layout、状态......
  • python调用其他.py文件
    一、python程序本质python是一个解释性的动态编程语言,所以它不需要像编译型的语言一样在程序编写完成之后还要通过编译才可以去使用。python编写的所有程序都是一个以py后......
  • 使用Python画出直方图
    https://zhuanlan.zhihu.com/p/476643798 它们之间的区别在于pandas.DataFrame.plot.hist将整个dataframe的数据展示在一幅图上,而pandas.DataFrame.hist会调用pandas.Da......
  • 4.6字符串大战 python
    1字符串排序有多篇文章输入,每篇文章分为标题行和正文行,每篇文章输入时标题和正文各占一行。需要统计所有文章中出现的热词并输出topN的热词。title中的词权重为3,text中权......