[英]Reading and writing files in order - Python
抱歉,python是一種新語言。
所以我有5個文件可以說。 item1.txt,item2.txt,item3.txt,item4.txt和item5.txt。 我試圖在目錄上調用,以便它選擇第一個文件(item1.txt)並打印其內容,然后當我再次調用該函數(item2.txt)並在文件中打印其內容時...然后(item3.txt),然后(item4.txt)。
順序很重要,系統必須知道已打印了哪個文件,以便可以在第一個文件之后打印行中的下一個文件。 首先打印item1.txt的內容,然后打印item2.txt。
嘗試使用:
for infile in sorted(glob.glob('*.txt')):
print "Current File Being Processed is: " + infile
但是問題是需要添加目錄,並且系統需要知道在此文件之前打印了什么文件及其內容。
抱歉,這令人困惑。
幫助表示贊賞。
這是您要搜索的內容嗎?
import glob
path = "path/to/your/txt/files/"
for infile in sorted(glob.glob(path + '*.txt')):
print("Current File Being Processed is: " + path + infile)
如果需要知道完整路徑,可以使用os.path.join。
例如,一個搜索當前目錄中所有文件的腳本如下所示:
import os
import os.path
import re
# look for all files in current working directory, including subdirs
for (root, folders, files) in os.walk(os.getcwd()):
for file in files:
fullpath = os.path.join(root, file)
print(fullpath)
希望這可以幫助。
但是問題是需要添加目錄...
為此,請使用os.path
的方法。
您可以執行pwd = os.getcwd()
來獲取當前的工作目錄(與glob('*.txt')
搜索的目錄相同),然后使用os.path.join(pwd, infile)
。 但是對於特殊情況,當您只有相對於當前目錄的路徑時,您可能想要的是os.path.abspath
。 所以:
for infile in sorted(glob.glob('*.txt')):
inpath = os.path.abspath(infile)
print "Current File Being Processed is: " + inpath
並且系統需要知道先打印了什么文件及其內容。
要獲取文件的內容,必須open
它,然后從文件中read
,如下所示:
for infile in sorted(glob.glob('*.txt')):
inpath = os.path.abspath(infile)
print "Current File Being Processed is: " + inpath
with open(inpath) as infileobj:
contents = infileobj.read()
print contents
通常,您實際上並不是真正希望將整個文件讀為一個大字符串,而只是想在文件的每一行上做一些工作。 為此,您可以僅使用for
語句,就像for
sorted
返回的字符串列表進行處理一樣,將文件視為一串行:
for infile in sorted(glob.glob('*.txt')):
inpath = os.path.abspath(infile)
print "Current File Being Processed is: " + inpath
with open(inpath) as infileobj:
for line in infileobj:
print line.rstrip('\n')
( rstrip('\\n')
是因為每一行都以換行符結尾,但是print
添加了自己的換行符,並且您不想在文件的每一行之間留空行。)
這樣做的好處是您不必將整個文件讀入內存即可打印出來。 如果您正在處理微小的文件,這沒什么大不了的,但是對於較大的文件,它卻有很大的不同。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.