我有一个看起来像的文本文件:
John: 27
Micheal8483: 160
Mary Smith: 57
Adam 22: 68
Patty: 55
等等。它们是用户名,这就是为什么他们的名字偶尔包含数字的原因。我想要做的是检查它们的每个数字(“:”之后的数字),并获得3个名称,这些数字的值最接近整数(特别是名为targetNum)。它总是积极的。
我尝试了很多东西,但我是Python的新手,我不确定如何解决这个问题。任何帮助表示赞赏!
答案 0 :(得分:1)
您可以将文件解析为名称/数字对列表。然后sort列出数字和targetNum
之间的差异。然后,列表的前三项将包含所需的名称:
users = []
with open("file.txt") as f:
for line in f:
name, num = line.split(":")
users.append((name, int(num)))
targetNum = 50
users.sort(key=lambda pair: abs(pair[1] - targetNum))
print([pair[0] for pair in users[:3]]) # ['Patty', 'Mary Smith', 'Adam 22']
答案 1 :(得分:0)
你可以在这里使用一些正则表达式:
import re
pattern=r'(\w.+)?:\s(\d+)'
data_1=[]
targetNum = 50
with open('new_file.txt','r') as f:
for line in f:
data=re.findall(pattern,line)
for i in data:
data_1.append((int(i[1])-targetNum,i[0]))
print(list(map(lambda x:x[1],data_1[-3:])))
输出:
['Mary Smith', 'Adam 22', 'Patty']