亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > python 使用fileinput讀取文件

python 使用fileinput讀取文件

熱門標(biāo)簽:西藏智能外呼系統(tǒng)五星服務(wù) 清遠(yuǎn)360地圖標(biāo)注方法 平頂山外呼系統(tǒng)免費 原裝電話機(jī)器人 千陽自動外呼系統(tǒng) 400電話申請服務(wù)商選什么 工廠智能電話機(jī)器人 在哪里辦理400電話號碼 江蘇客服外呼系統(tǒng)廠家

fileinput 是 Python 的內(nèi)置模塊,但我相信,不少人對它都是陌生的。今天我把 fileinput 的所有的用法、功能進(jìn)行詳細(xì)的講解,并列舉了一些非常實用的案例,對于理解和使用它可以說完全沒有問題。

1. 從標(biāo)準(zhǔn)輸入中讀取

當(dāng)你的 Python 腳本沒有傳入任何參數(shù)時,fileinput 默認(rèn)會以 stdin 作為輸入源

# demo.py
import fileinput

for line in fileinput.input():
    print(line) 

效果如下,不管你輸入什么,程序會自動讀取并再打印一次,像個復(fù)讀機(jī)似的。

$ python demo.py 
hello
hello

python
python

2. 單獨打開一個文件

單獨打開一個文件,只需要在 files 中輸入一個文件名即可

import fileinput

with fileinput.input(files=('a.txt',)) as file:
    for line in file:
        print(f'{fileinput.filename()} 第{fileinput.lineno()}行: {line}', end='') 

其中 a.txt 的內(nèi)容如下

hello
world

執(zhí)行后就會輸出如下

$ python demo.py
a.txt 第1行: hello
a.txt 第2行: world

需要說明的一點是,fileinput.input() 默認(rèn)使用 mode='r' 的模式讀取文件,如果你的文件是二進(jìn)制的,可以使用mode='rb' 模式。fileinput 有且僅有這兩種讀取模式。

3. 批量打開多個文件

從上面的例子也可以看到,我在 fileinput.input 函數(shù)中傳入了 files 參數(shù),它接收一個包含多個文件名的列表或元組,傳入一個就是讀取一個文件,傳入多件就是讀取多個文件。

import fileinput

with fileinput.input(files=('a.txt', 'b.txt')) as file:
    for line in file:
        print(f'{fileinput.filename()} 第{fileinput.lineno()}行: {line}', end='') 

a.txt 和 b.txt 的內(nèi)容分別是

$ cat a.txt
hello
world
$ cat b.txt
hello
python

運(yùn)行后輸出結(jié)果如下,由于 a.txt 和 b.txt 的內(nèi)容被整合成一個文件對象 file ,因此 fileinput.lineno() 只有在讀取一個文件時,才是原文件中真實的行號。

$ python demo.py
a.txt 第1行: hello
a.txt 第2行: world
b.txt 第3行: hello
b.txt 第4行: python

如果想要在讀取多個文件的時候,也能讀取原文件的真實行號,可以使用 fileinput.filelineno() 方法

import fileinput

with fileinput.input(files=('a.txt', 'b.txt')) as file:
    for line in file:
        print(f'{fileinput.filename()} 第{fileinput.filelineno()}行: {line}', end='')

運(yùn)行后,輸出如下

$ python demo.py
a.txt 第1行: hello
a.txt 第2行: world
b.txt 第1行: hello
b.txt 第2行: python

這個用法和 glob 模塊簡直是絕配

import fileinput
import glob

for line in fileinput.input(glob.glob("*.txt")):
    if fileinput.isfirstline():
        print('-'*20, f'Reading {fileinput.filename()}...', '-'*20)
    print(str(fileinput.lineno()) + ': ' + line.upper(), end="")

運(yùn)行效果如下

$ python demo.py
-------------------- Reading b.txt... --------------------
1: HELLO
2: PYTHON
-------------------- Reading a.txt... --------------------
3: HELLO
4: WORLD

4. 讀取的同時備份文件

fileinput.input 有一個 backup 參數(shù),你可以指定備份的后綴名,比如 .bak

import fileinput


with fileinput.input(files=("a.txt",), backup=".bak") as file:
    for line in file:
        print(f'{fileinput.filename()} 第{fileinput.lineno()}行: {line}', end='') 

運(yùn)行的結(jié)果如下,會多出一個 a.txt.bak 文件

$ ls -l a.txt*
-rw-r--r--  1 MING  staff  12  2 27 10:43 a.txt

$ python demo.py
a.txt 第1行: hello
a.txt 第2行: world

$ ls -l a.txt*
-rw-r--r--  1 MING  staff  12  2 27 10:43 a.txt
-rw-r--r--  1 MING  staff  42  2 27 10:39 a.txt.bak

5. 標(biāo)準(zhǔn)輸出重定向替換

fileinput.input 有一個 inplace 參數(shù),表示是否將標(biāo)準(zhǔn)輸出的結(jié)果寫回文件,默認(rèn)不取代

請看如下一段測試代碼

import fileinput

with fileinput.input(files=("a.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...") 

運(yùn)行后,會發(fā)現(xiàn)在 for 循環(huán)體內(nèi)的 print 內(nèi)容會寫回到原文件中了。而在 for 循環(huán)體外的 print 則沒有變化。

$ cat a.txt
hello
world

$ python demo.py
[INFO] task is started...
[INFO] task is closed...

$ cat a.txt 
a.txt 第1行: hello
a.txt 第2行: world

利用這個機(jī)制,可以很容易的實現(xiàn)文本替換。

import sys
import fileinput

for line in fileinput.input(files=('a.txt', ), inplace=True):
    #將Windows/DOS格式下的文本文件轉(zhuǎn)為Linux的文件
    if line[-2:] == "\r\n":  
        line = line + "\n"
    sys.stdout.write(line)

附:如何實現(xiàn) DOS 和 UNIX 格式互換以供程序測試,使用 vim 輸入如下指令即可

DOS轉(zhuǎn)UNIX::setfileformat=unix
UNIX轉(zhuǎn)DOS::setfileformat=dos

6. 不得不介紹的方法

如果只是想要 fileinput 當(dāng)做是替代 open 讀取文件的工具,那么以上的內(nèi)容足以滿足你的要求。

  • fileinput.filenam()

返回當(dāng)前被讀取的文件名。在第一行被讀取之前,返回 None。

  • fileinput.fileno()

返回以整數(shù)表示的當(dāng)前文件“文件描述符”。當(dāng)未打開文件時(處在第一行和文件之間),返回 -1。

  • fileinput.lineno()

返回已被讀取的累計行號。在第一行被讀取之前,返回 0。在最后一個文件的最后一行被讀取之后,返回該行的行號。

  • fileinput.filelineno()

返回當(dāng)前文件中的行號。在第一行被讀取之前,返回 0。在最后一個文件的最后一行被讀取之后,返回此文件中該行的行號。

但若要想基于 fileinput 來做一些更加復(fù)雜的邏輯,也許你會需要用到如下這幾個方法

  • fileinput.isfirstline()

如果剛讀取的行是其所在文件的第一行則返回 True,否則返回 False。

  • fileinput.isstdin()

如果最后讀取的行來自 sys.stdin 則返回 True,否則返回 False。

  • fileinput.nextfile()

關(guān)閉當(dāng)前文件以使下次迭代將從下一個文件(如果存在)讀取第一行;不是從該文件讀取的行將不會被計入累計行數(shù)。直到下一個文件的第一行被讀取之后文件名才會改變。在第一行被讀取之前,此函數(shù)將不會生效;它不能被用來跳過第一個文件。在最后一個文件的最后一行被讀取之后,此函數(shù)將不再生效。

  • fileinput.close()

關(guān)閉序列。

7. 進(jìn)階一點的玩法

在 fileinput.input() 中有一個 openhook 的參數(shù),它支持用戶傳入自定義的對象讀取方法。

若你沒有傳入任何的勾子,fileinput 默認(rèn)使用的是 open 函數(shù)。

fileinput  為我們內(nèi)置了兩種勾子供你使用

  • fileinput.hook_compressed(*filename*, *mode*)

使用 gzip 和 bz2 模塊透明地打開 gzip 和 bzip2 壓縮的文件(通過擴(kuò)展名 '.gz' 和 '.bz2' 來識別)。如果文件擴(kuò)展名不是 '.gz' 或 '.bz2',文件會以正常方式打開(即使用 open() 并且不帶任何解壓操作)。使用示例: fi = fileinput.FileInput(openhook=fileinput.hook_compressed)

  • fileinput.hook_encoded(*encoding*, *errors=None*)

返回一個通過 open() 打開每個文件的鉤子,使用給定的 encoding 和 errors 來讀取文件。使用示例: fi = fileinput.FileInput(openhook=fileinput.hook_encoded("utf-8", "surrogateescape"))

如果你自己的場景比較特殊,以上的三種勾子都不能滿足你的要求,你也可以自定義。

這邊我舉個例子來拋磚引玉下

假如我想要使用 fileinput 來讀取網(wǎng)絡(luò)上的文件,可以這樣定義勾子。

  • 先使用 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

直接將這個函數(shù)傳給 openhook 即可

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

運(yùn)行后按預(yù)期一樣將 CSDN 的 robots 的文件打印了出來

User-agent: * 
Disallow: /scripts 
Disallow: /public 
Disallow: /css/ 
Disallow: /images/ 
Disallow: /content/ 
Disallow: /ui/ 
Disallow: /js/ 
Disallow: /scripts/ 
Disallow: /article_preview.html* 
Disallow: /tag/
Disallow: /*?*
Disallow: /link/

Sitemap: https://www.csdn.net/sitemap-aggpage-index.xml
Sitemap: https://www.csdn.net/article/sitemap.txt 

8. 列舉一些實用案例

案例一:讀取一個文件所有行

import fileinput
for line in fileinput.input('data.txt'):
  print(line, end="")

案例二:讀取多個文件所有行

import fileinput
import glob

for line in fileinput.input(glob.glob("*.txt")):
    if fileinput.isfirstline():
        print('-'*20, f'Reading {fileinput.filename()}...', '-'*20)
    print(str(fileinput.lineno()) + ': ' + line.upper(), end="")

案例三:利用fileinput將CRLF文件轉(zhuǎn)為LF

import sys
import fileinput

for line in fileinput.input(files=('a.txt', ), inplace=True):
    #將Windows/DOS格式下的文本文件轉(zhuǎn)為Linux的文件
    if line[-2:] == "\r\n":  
        line = line + "\n"
    sys.stdout.write(line)

案例四:配合 re 做日志分析:取所有含日期的行

#--樣本文件--:error.log
aaa
1970-01-01 13:45:30  Error: **** Due to System Disk spacke not enough...
bbb
1970-01-02 10:20:30  Error: **** Due to System Out of Memory...
ccc

#---測試腳本---
import re
import fileinput
import sys

pattern = '\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}'

for line in fileinput.input('error.log',backup='.bak',inplace=1):
    if re.search(pattern,line):
        sys.stdout.write("=> ")
        sys.stdout.write(line)

#---測試結(jié)果---
=> 1970-01-01 13:45:30  Error: **** Due to System Disk spacke not enough...
=> 1970-01-02 10:20:30  Error: **** Due to System Out of Memory...

案例五:利用fileinput實現(xiàn)類似于grep的功能

import sys
import re
import fileinput

pattern= re.compile(sys.argv[1])
for line in fileinput.input(sys.argv[2]):
    if pattern.match(line):
        print(fileinput.filename(), fileinput.filelineno(), line)

$ ./demo.py import.*re *.py
#查找所有py文件中,含import re字樣的
addressBook.py  2   import re
addressBook1.py 10  import re
addressBook2.py 18  import re
test.py         238 import re

9. 寫在最后

fileinput 是對 open 函數(shù)的再次封裝,在僅需讀取數(shù)據(jù)的場景中, fileinput 顯然比 open 做得更專業(yè)、更人性,當(dāng)然在其他有寫操作的復(fù)雜場景中,fileinput 就無能為力啦,本身從 fileinput 的命名上就知道這個模塊只專注于輸入(讀)而不是輸出(寫)。

以上就是python 使用fileinput讀取文件的詳細(xì)內(nèi)容,更多關(guān)于python 用fileinput讀取文件的資料請關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • Python fileinput模塊如何逐行讀取多個文件
  • python文件處理fileinput使用方法詳解
  • python 使用sys.stdin和fileinput讀入標(biāo)準(zhǔn)輸入的方法
  • Python使用os模塊和fileinput模塊來操作文件目錄
  • Python中的fileinput模塊的簡單實用示例
  • Python fileinput模塊使用實例
  • Python fileinput模塊使用實例
  • python使用fileinput模塊實現(xiàn)逐行讀取文件的方法
  • Python fileinput模塊使用介紹

標(biāo)簽:錦州 白城 西安 安慶 股票 隨州 天水 日照

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《python 使用fileinput讀取文件》,本文關(guān)鍵詞  python,使用,fileinput,讀取,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《python 使用fileinput讀取文件》相關(guān)的同類信息!
  • 本頁收集關(guān)于python 使用fileinput讀取文件的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    国产成人精品综合在线| 午夜精品国产自在现线拍| 免费国产在线观看不卡| 国产精品自拍亚洲| 精品在线观看国产| 亚洲www美色| 成人a级高清视频在线观看| 久久国产一久久高清| 韩国毛片| 欧美电影免费| 天天做人人爱夜夜爽2020| 日韩综合| 欧美另类videosbestsex久久 | 亚州视频一区二区| 欧美激情在线精品video| 国产亚洲免费观看| 国产韩国精品一区二区三区| 黄色免费三级| 亚洲女人国产香蕉久久精品| 日日爽天天| 日本免费乱人伦在线观看| 美女免费毛片| 一级毛片视频播放| 国产一区免费观看| 尤物视频网站在线观看| 久久国产影院| 99色视频在线观看| 中文字幕一区二区三区精彩视频| 999久久狠狠免费精品| 色综合久久久久综合体桃花网| 日本伦理网站| 久久精品成人一区二区三区| 99色视频在线| 免费国产一级特黄aa大片在线| 精品视频免费观看| 国产一级强片在线观看| 国产成人精品影视| 国产成人精品综合久久久| 国产伦精品一区二区三区无广告| 美女免费毛片| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 日本免费乱人伦在线观看| 麻豆污视频| 国产网站免费视频| 国产91丝袜在线播放0| 久久成人性色生活片| 精品国产香蕉在线播出| 日日夜夜婷婷| 亚洲www美色| 日韩中文字幕在线亚洲一区| 亚洲精品中文字幕久久久久久| 国产网站免费在线观看| 黄色免费三级| 日日日夜夜操| 黄色免费三级| 四虎影视精品永久免费网站| 美女被草网站| 欧美激情伊人| 久久精品人人做人人爽97| 亚洲 欧美 成人日韩| 欧美日本免费| 日日夜夜婷婷| 亚洲精品久久玖玖玖玖| 尤物视频网站在线| 国产成人精品综合| 国产一区二区福利久久| 国产伦精品一区三区视频| 久久精品人人做人人爽97| 中文字幕97| 欧美日本免费| 九九精品久久久久久久久| 日本特黄特黄aaaaa大片 | 天天色色网| 麻豆污视频| 精品视频在线看| 久久精品欧美一区二区| 久久99这里只有精品国产| 精品国产一区二区三区久| 九九久久99| 欧美国产日韩在线| 久久国产精品自由自在| 一本伊大人香蕉高清在线观看| 99久久精品国产高清一区二区| 一级女性全黄生活片免费| 欧美激情一区二区三区视频高清 | 一级女性全黄久久生活片| 欧美激情伊人| 午夜精品国产自在现线拍| 国产国语对白一级毛片| 黄视频网站在线看| 色综合久久久久综合体桃花网| 精品在线观看一区| 亚洲精品中文字幕久久久久久| 深夜做爰性大片中文| 国产一区二区精品| 一级毛片视频在线观看| 国产成人女人在线视频观看| 国产极品精频在线观看| 国产伦久视频免费观看 视频| 精品国产一区二区三区免费 | 国产极品精频在线观看| 午夜在线亚洲| 在线观看成人网| 国产成人精品综合久久久| 你懂的国产精品| 国产麻豆精品视频| 韩国毛片免费| 精品国产亚洲一区二区三区| 久草免费在线观看| 精品视频在线观看免费| 99热精品在线| 国产视频久久久| 国产综合成人观看在线| 日韩在线观看免费| 精品国产亚洲一区二区三区| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 久久久成人网| 亚洲女人国产香蕉久久精品| 一级女性大黄生活片免费| 精品国产一区二区三区久| 色综合久久天天综合| 精品视频一区二区| 久草免费资源| 精品国产亚洲人成在线| 欧美日本国产| 日本伦理网站| 成人免费观看网欧美片| 欧美另类videosbestsex久久| a级黄色毛片免费播放视频| 高清一级淫片a级中文字幕| 久久国产一区二区| 亚洲精品中文一区不卡| 黄视频网站在线看| 亚洲精品影院一区二区| 久久精品欧美一区二区| 成人免费一级纶理片| 黄色免费三级| 久久99爰这里有精品国产| 日韩中文字幕在线观看视频| 日本免费看视频| 久久国产影视免费精品| 日韩一级黄色| 精品国产一区二区三区国产馆| a级毛片免费全部播放| 夜夜操网| 久久国产一久久高清| 韩国毛片免费| 日本特黄特色aaa大片免费| 999久久久免费精品国产牛牛| 午夜精品国产自在现线拍| 国产一区二区精品久久91| 成人免费福利片在线观看| 欧美激情影院| 国产视频在线免费观看| 高清一级淫片a级中文字幕| 国产一区二区精品久久91| 欧美激情伊人| 精品国产亚洲一区二区三区| 九九精品影院| 欧美a免费| 久久久成人影院| 欧美大片一区| 精品国产一区二区三区久久久狼| 国产不卡福利| 日韩欧美一二三区| 成人影视在线观看| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 超级乱淫伦动漫| 成人影视在线观看| 日韩中文字幕一区| 国产精品12| 你懂的国产精品| 欧美大片一区| 成人a大片在线观看| 毛片高清| 精品国产一区二区三区久| 成人高清免费| 一a一级片| 欧美日本免费| 精品久久久久久中文字幕一区| 久久99爰这里有精品国产| 九九干| 精品国产一区二区三区久久久狼| 尤物视频网站在线观看| 亚洲精品影院一区二区| 精品视频在线观看一区二区三区| 日本在线www| 午夜在线亚洲| 黄视频网站免费看| 欧美18性精品| 一级毛片视频免费| 欧美a级片免费看| 午夜精品国产自在现线拍| 国产高清在线精品一区二区| 欧美日本免费| 四虎久久精品国产| 精品国产一区二区三区久久久狼| 国产视频一区二区在线播放| 日韩av成人| 久久精品成人一区二区三区|