1

我需要在 MySQL 中存储一个嵌套字典列表。我看到的唯一方法是将其转换为字符串并将其存储在一个TEXT字段中。挑战是如何将它从字符串转换回来?

例如:

import json                                                                     

val1 = {"aaa":1}                                                                
val2 = {"bbb":2}                                                                   
val3 = {"ccc":3}                                                                   

values = [                                                                         
          json.dumps(val1),                                                        
          json.dumps(val2),                                                        
          json.dumps(val3),                                                        
]                                                                                  

values_str = str(values)                                                           

values_str                                                                         
#'[\'{"aaa": 1}\', \'{"bbb": 2}\', \'{"ccc": 3}\']' 

现在我可以安全地将它存储在 MySQL 中,但是如何将它转换回原来的形状。

我尝试使用.split(),但没有正确拆分它。此外,我还没有包含,在字典中,但它们会在那里,所以随地吐痰,不是一种选择

4

2 回答 2

4

无需将 json 字符串放入值列表中,只需 json 对字典列表进行编码。

values = [val1, val2, val3]
values_str = json.dumps(values)

# Then read it back
values = json.loads(values_str)

如果你真的必须这样做,那么你可以这样做

import ast
values = ast.literal_eval(values_str)
values = [json.loads(item) for item in values]
于 2013-10-29T16:40:42.110 回答
2

试试泡菜模块。您可以将对象序列化为字符串,然后将它们转换回原始对象。

import pickle

val1 = {"aaa":1}                                                                
val2 = {"bbb":2}                                                                   
val3 = {"ccc":3} 
a = pickle.dumps((val1,val2,val3)) # pickle the objects
# "((dp0\nS'aaa'\np1\nI1\ns(dp2\nS'bbb'\np3\nI2\ns(dp4\nS'ccc'\np5\nI3\nstp6\n."

# store in sql database as string

b = pickle.loads(a) # get original objects
# ({'aaa': 1}, {'bbb': 2}, {'ccc': 3})
于 2013-10-29T16:42:20.100 回答