[英]JSON Dump a string surrounded by single quotes and containing escaped single quotes
我正在开发 Django web 应用程序,我遇到了问题。 我有一个页面,在其中列出了 MySQL 表中的所有结果,它工作正常。
{% for row in db_list %}
<tr>
<th scope="row">{{ row.description }}</th>
<td>
<button type="submit" name="instance" value="{{ row }}" class="btn btn-primary" title="OPEN TABLE" id="test"><i class="fas fa-list-ul"></i></button>
</td>
</tr>
{% endfor %}
根据选择,我必须显示所选表的关系,并且可以通过变通方法正常工作,但这并不通用。
如您所见,我正在做的是传回 json 的单行。
db_list 是:
{
"db_list": [
{
"description": "description",
"table_name": "table_name",
"database_name": "database_name"
},
{
"description": "description",
"table_name": "table_name",
"database_name": "database_name"
},
{
"description": "description",
"table_name": "table_name",
"database_name": "database_name"
}
]
}
我希望像这样传输 json:
{
"description": "description",
"table_name": "table_name",
"database_name": "database_name"
}
'{ \'description\': \'description\', \'table_name\': \'table_name\', \'database_name\': \'database_name\' }'
'"{ \'description\': \'description\', \'table_name\': \'table_name\', \'database_name\': \'database_name\' }"'
如果我尝试做 dumped_json['description'] 它说参数必须是 integer .. 因为它当然仍然不是一个字典。 即使我把它扔了。
我已经尝试过使用 dict(),但没有。
我已经尝试用其他引号或什么都不替换引号,但没有。 没有引号就不能转储,如果我用双引号替换,我会一直看到转义。
问题是:从技术上讲,它一直是一个字符串。 如果我尝试打印它,当然它没有 \ 转义。 json 的 [0] 是 { (相反,是“如果我做了转储)而不是 '。已经尝试过 ascii 解码和所有这些东西。似乎 \ 转义不是“物理”存在于字符串..
我想感谢我的男孩@Seth250,他给了我一半的解决方案
我所要做的就是简单地使用literal_eval,而不是用json lib 转储它,而是简单地将literal_eval'ed 字符串包围成一个字典。
instance = ast.literal_eval(string_with_escapes)
instance_json = dict(instance)
结果实际上是:
{
'description': 'description',
'table_name': 'table_name',
'database_name': 'database_name'
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.