遍历文本文件中的数字

Iterating over numbers in a text file

我有一个包含 1,000 个数字的 .txt 文件,这些数字仅由 ',' 分隔。当我将文件打开到 python 时,它会将其读取为一个大字符串,因此只有一行。我需要找出一种方法将逗号之间的每个数字转换为 int,以便我可以遍历它们。这是我到目前为止的代码:

with open('HW5.txt') as f:
    data = f.read()
    print(type(data))
    newdata = data.replace(',',' ')
    data_seperate = newdata.replace(' ', '\n')
    print(data_seperate)
    print(len(data_seperate))
f.close()

它在新行上打印出每个数字,但数字仍然是字符串,并且 python 将每个单独的数字计为一个字符,而不是使每个数字成为一个整数。 我该如何处理?我刚开始使用 .txt 文件,所以这些属性让我很困惑。试图转换 print(int(data_seperate)) returns 这个错误:

ValueError: invalid literal for int() with base 10: '798\n441\n687\n780\n103\n405\n363\n66\n481\n171\n549\n449\n135\n229\n689\n248\n374\n697\n502\n209\n699\n684\n377\n235\n819\n471\n189\n43\n696\n999\n769\n501\n148\n474\n733\n729\n427\n710\n911\n207\n2

这是使用 str.splitmap 的一种方法。请注意,我在这里使用 rstrip() 以防文件中有尾随换行符,正如我们在这里所做的那样。

sample_file_contents = """\
1,2,3,4,5,6,7,8,9
"""

num_list = sample_file_contents.rstrip().split(',')
numbers = list(map(int, num_list))

print(numbers)

输出:

[1, 2, 3, 4, 5, 6, 7, 8, 9]

map:

with open("HW5.txt") as f:
    data = [*map(int, f.read().split(","))]

>>> data
[798, 441, 687, 780, 103, 405, 363, 66, 481, 171, 549, 449, 135, 229,
 689, 248, 374, 697, 502, 209, 699, 684, 377, 235, 819, 471, 189, 43,
 696, 999, 769, 501, 148, 474, 733, 729, 427, 710, 911, 207, 25, 785,
 855, 550, 481, 735, 832, 791, 970, 225, 559, 182, 922, 717, 723, 113,
 260, 166, 294, 97, 3, 323, 835, 18, 653, 876, 264]