Python:从JSON转储中删除双引号

时间:2013-09-06 00:41:35

标签: python json

我有一个数据库,它按以下格式将行作为列表返回:

data = ['(1000,"test value",0,0.00,0,0)', '(1001,"Another test value",0,0.00,0,0)']

之后,我使用json_str = json.dumps(data)来获取JSON字符串。应用json.dumps()后,我得到以下输出:

json_str = ["(1000,\"test value\",0,0.00,0,0)", "(1001,\"Another test value\",0,0.00,0,0)"]

但是,我需要以下格式的JSON字符串:

json_str = [(1000,\"test value\",0,0.00,0,0), (1001,\"Another test value\",0,0.00,0,0)]

基本上,我想删除周围的双引号。我尝试使用json_str = json_str.strip('"')完成此操作,但这不起作用。然后,我尝试了json_str = json_str.replace('"', ''),但这也删除了转义引号。

有没有人知道实现这一目标的方法,或者Python中是否有与json.dumps()类似的函数,它产生相同的结果,但没有周围的双引号?

1 个答案:

答案 0 :(得分:1)

您正在转储字符串列表,因此json.dumps完全符合您的要求。对你的问题而言,相当丑陋的解决方案可能就像下面这样。

def split_and_convert(s):
    bits = s[1:-1].split(',')
    return (
        int(bits[0]), bits[1], float(bits[2]),
        float(bits[3]), float(bits[4]), float(bits[5])
    )

data_to_dump = [split_and_convert(s) for s in data]
json.dumps(data_to_dump)