我想从我拥有的文本文件中创建一个字典,其内容为“字典”格式。以下是文件包含的示例:
{'fawn': [1], 'sermersheim': [3], 'sonji': [2], 'scheuring': [2]}
除了它包含 125,000 个条目之外,就是这样。我可以使用 read() 读取文本文件,但即使我使用
初始化变量,它也会创建文件文字文本的变量dict = {}
最佳答案
您可以使用 eval
内置。例如,如果每个字典条目都在不同的行上,这将起作用:
dicts_from_file = []
with open('myfile.txt','r') as inf:
for line in inf:
dicts_from_file.append(eval(line))
# dicts_from_file now contains the dictionaries created from the text file
或者,如果文件只是一个大字典(甚至是多行),您可以这样做:
with open('myfile.txt','r') as inf:
dict_from_file = eval(inf.read())
这可能是最简单的方法,但也不是最安全的。正如其他人在回答中提到的那样,eval
具有一些固有的安全风险。正如 JBernardo 所提到的,替代方法是使用 ast.literal_eval
这比 eval 安全得多,因为它只会评估包含文字的字符串。导入 ast
模块后,您可以简单地将上述示例中对 eval
的所有调用替换为 ast.literal_eval
。
如果您使用的是 Python 2.4,您将不会拥有 ast
模块,也不会拥有 with
陈述。代码看起来更像这样:
inf = open('myfile.txt','r')
dict_from_file = eval(inf.read())
inf.close()
别忘了调用 inf.close()
。 with
语句的美妙之处在于它们会为您完成,即使 with
语句中的代码块引发异常。
关于Python:从字典格式的文本/文件创建字典,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9314824/