亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

在python中逐行解析文本

在python中逐行解析文本

搖曳的薔薇 2022-07-26 20:54:07
我只想讓我的程序讀取文件中的一行,對行中的文本執行一些操作,然后移至下一行,直到文件中的所有行都完成。這是我到目前為止所擁有的:with open(str(filepath), r) as fp:     for line in fp:         rdline = fp.readline()          doSomething(rdline)但是,這不起作用。我應該如何處理這個?我不想將所有行都轉換為字典或列表,因為我將處理包含大量行的文件。
查看完整描述

3 回答

?
白衣非少年

TA貢獻1155條經驗 獲得超0個贊

嘗試這個:


with open('filepath') as infile:

  for row in infile:

    do_somthing(row.strip())

再見


查看完整回答
反對 回復 2022-07-26
?
達令說

TA貢獻1821條經驗 獲得超6個贊

正如我在評論中所說,這rdline = fp.readline()不是必需的,因為您已經fp在 for 循環上進行迭代。


with open(filepath) as f:

    for line in f: 

        do_something(line)


查看完整回答
反對 回復 2022-07-26
?
忽然笑

TA貢獻1806條經驗 獲得超5個贊

我認為您的代碼中出現的錯誤是


with open(str(filepath), 'r') as fp:

    lines = fp.readlines() 

    for line in lines:

        do_something(line)


將 open 函數的第二個參數作為字符串給出。


(或者)


如果文件很大,你可以通過這種方法


with open(str(filepath), 'r') as fp:

    line = fp.readline() 

    while line:

        do_something(line)

        line = fp.readline()


查看完整回答
反對 回復 2022-07-26
  • 3 回答
  • 0 關注
  • 108 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號