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

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

如何在python中找到相同的數字?

如何在python中找到相同的數字?

慕婉清6462132 2022-11-09 16:41:25
我在 Python 3.8.0 中遇到了這個程序的問題。我有兩個文本文件(它們不能合并)。它們包含大約 1000 個數字,每個 15 位長(看起來像這樣104988537042058)。我必須找到相同的數字。有人可以幫助我嗎?我有點失落。我寫了這個程序,但我可能在某個地方有錯誤。我是編程新手,找不到問題所在。A=open("A.txt",mode="r")B=open("B.txt",mode="r")out=open("Spol.txt", mode="w+")#print(A)#print(B)X=""for lineA in A:    for lineB in B:        if lineA==lineB:            X+=(lineA)        else:            ()        breakA.close()B.close()out.write(X)out.close()
查看完整描述

4 回答

?
FFIVE

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

您的代碼有兩個問題,break第一次與 lineB 比較后將退出循環。另一個問題是當您讀取文件時,您使用設置在文件開頭的光標,一旦您讀取文件,光標就位于末尾,因此每次嘗試使用相同的光標時它都會為空再次處理而不重置光標。由于您似乎不關心重復項,因此我編寫了以下代碼,它應該可以完成您想要的操作:


with open("A.txt") as Af, open("B.txt") as Bf:

    numsA = {int(lineA.strip()) for lineA in Af}

    numsB = {int(lineB.strip()) for lineB in Bf}

    print(numsA & numsB)


查看完整回答
反對 回復 2022-11-09
?
溫溫醬

TA貢獻1752條經驗 獲得超4個贊

迭代 B 的內部循環不起作用,或者更準確地說,對于 A 的第一行,它只工作一次。之后,它已經在 B 的末尾。啊,是的,break也是 - 將在第一次迭代后退出的內循環。你可能打算把它放在里面if

您可以在內部循環之前重新打開 B 。無論如何,這非常慢 - 盡管對于 1000 個數字仍然可以。最好將 A 的內容讀入集合,然后遍歷 B,尋找集合中存在的數字。

或者,如果您處于類 unix 環境中,只需cat A.txt B.txt| sort | uniq -d假設您在 A 或 B 中沒有重復。如果您仍然可以在 shell 中執行此操作
(sort A.txt| uniq; sort B.txt | uniq) | sort | uniq -d


查看完整回答
反對 回復 2022-11-09
?
素胚勾勒不出你

TA貢獻1827條經驗 獲得超9個贊

您將不需要else. 將 break 移到條件內部,這樣它只會在找到匹配項時才中斷內部循環:


file_A=open("A.txt",mode="r")

file_B=open("B.txt",mode="r")

out=open("Spol.txt", mode="w+")


for lineA in A:

    for lineB in B:

        if lineA==lineB:

            X+=(lineA)

            break


A.close()

B.close()

out.write(X)

out.close()


查看完整回答
反對 回復 2022-11-09
?
炎炎設計

TA貢獻1808條經驗 獲得超4個贊

假設每個文件中的每一行都是一個數字,您可以使用 python集合將所有行從第一個文件加載到一個集合,并將所有行從第二個文件加載到另一個集合,然后使用集合交集。例子:


# Reads into a set the content of file1 line by line

with open('file1.txt', 'r') as fs:

    file1_set = set(fs.readlines())


# Reads into a set the content of file2 line by line

with open('file2.txt', 'r') as fs:

    file2_set = set(fs.readlines())


# After both files contents (the numbers) are in sets

# then uses set intersection to find numbers appearing in both files

print(file1_set.intersection(file2_set))

最后一行將打印兩個文件中出現的所有數字


查看完整回答
反對 回復 2022-11-09
  • 4 回答
  • 0 關注
  • 200 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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