簡體   English   中英

處理內存中的文件

[英]Processing files in memory

我每一行都有一個文件

名稱1名稱2名稱3

我可以逐行讀取,拆分每行,處理一行並逐行輸出處理后的內容。

但是我想讀入整個文件,按中間列對其進行排序,然后以與輸入時相同的格式輸出整個排序后的文件。

我的第一次嘗試是將讀取的每一行拆分成一個元組列表,然后使用key =進行排序,然后重新加入每個元組並逐行輸出。

有沒有更Python的方式來做到這一點?

這樣的事情應該做:

with open('datafile') as fin:
    lines = list(fin)
    lines.sort(key=lambda line: line.split()[1])

with open('outfile','w') as fout:
    fout.writelines(lines)

一些注意事項:

  • 我的排序鍵有點難看。 但是,這樣做的好處是它可以保留與輸入文件中的行完全相同的行。 如果我們分割行然后進行排序,代碼可能會更漂亮,但是我們需要在輸出端正確地加入分割行(此外,空格的運行可能會丟失)

  • outfile可以與數據文件使用相同的文件名,以有效地“就地”進行更改

  • 如果您需要支持字段的引用( field1 "field 2" field3 ),那么您將需要查看csv模塊。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM