1

好的,所以我有一个像这样的元组的 txt 文件:

("Item1", 2, 3, 4)
("Item2", 3, 4, 5)
("Item3", 4, 5, 6)

每个元组将设置在自己的行上,就像第 0 项是字符串,其他 3 项是数字一样。现在对于我遇到麻烦的部分。基本上,我想读取元组并将其添加到列表中。这是我想出的:

with open('data.txt', 'r', encoding='utf-8') as file:
     lst = [line.strip() for line in file]

它将每个项目添加到列表中。但是,每个项目都会在此过程中转换为字符串。我将如何获得元组值。

4

2 回答 2

4

您可以使用ast.literal_eval()

import ast
with open('data.txt', 'r', encoding='utf-8') as file:
    lst = [ast.literal_eval(line.strip()) for line in file]

这可以安全地将字符串评估为元组。它比使用更安全eval()


您可能还需要考虑使用该pickle模块来写入和读取此类数据。这是一个例子:

import pickle
with open('a.txt', 'w') as myfile:
    pickle.dump([("Item1", 2, 3, 4), ("Item2", 3, 4, 5), ("Item3", 4, 5, 6)], myfile)

with open('a.txt', 'rb') as myfile2: # Open in bytes
    lst = pickle.load(myfile2)
    for tup2 in lst:
        print tup2
于 2013-09-15T22:17:45.977 回答
0

使用正则表达式?

def main():
    filename = sys.argv[1]
    fp = open(filename, 'r') # TODO error handling
    text = fp.read()
    fp.close()

    matches = re.findall(r'\(\"([^"]+)\",\s+(\d+),\s+(\d+),\s+(\d+)\)', text)
    for match in matches:
        (itemname, num1, num2, num3) = match
        print itemname, num1, num2, num3
        # Do whatever you want with them
于 2013-09-15T23:22:12.280 回答