将字符串输出转换为JSON

时间:2016-09-11 11:31:53

标签: python json

我通过API从外部系统(Salesforce Marketing Cloud)获取一些数据,并且我以下面的格式获取数据:

Results: [(List){
   Client =
      (ClientID){
         ID = 113903
      }
   PartnerKey = None
   CreatedDate = 2013-07-29 04:43:32.000073
   ModifiedDate = 2013-07-29 04:43:32.000073
   ID = 1966872
   ObjectID = None
   CustomerKey = "343431CD-031D-43C7-981F-51B778A5A47F"
   ListName = "PythonSDKList"
   Category = 578615
   Type = "Private"
   Description = "This list was created with the PythonSDK"
   ListClassification = "ExactTargetList"
 }]

它非常接近JSON,我想将其格式化为JSON文件,以便我可以将其导入我们的数据库。关于我如何做到这一点的任何想法?

由于

2 个答案:

答案 0 :(得分:2)

要转换数组,您可以使用     var jsonString = JSON.stringify(yourArray);

答案 1 :(得分:1)

它看起来像一个名为suds的对象,已经在Python中了。 Fuel-SDK使用它。

suds对象已经为你做了。只需调用您要查找的属性即可。


但是,如果你想把它作为一个dict,附加是它的常用功能:

from suds.sudsobject import asdict

def recursive_asdict(d):
    out = {}
    for k, v in asdict(d).iteritems():
        if hasattr(v, '__keylist__'):
            out[k] = recursive_asdict(v)
        elif isinstance(v, list):
            out[k] = []
            for item in v:
                if hasattr(item, '__keylist__'):
                    out[k].append(recursive_asdict(item))
                else:
                    out[k].append(item)
        else:
            out[k] = v
    return out

def suds_to_json(data):
    return json.dumps(recursive_asdict(data))

第一个将它转换为dict,第二个转换为适当的json。

一些有用的链接: https://fedorahosted.org/suds/wiki/Documentation