首页 > 解决方案 > 如何使用python将包含键值对的嵌套列表转换为json格式

问题描述

我有 ['key','value'] 格式列表,其中还包含子列表。如何在python中将嵌套列表转换为JSON格式

[[' key ', ' 1542633482511430199'
 ],
 ['value=>>>BasicData',
  [['isConfirmAndOrder', '0'],['brmRequestId', 'BR-2018-0000124'],
  ['requestType','batch'],['projectId', 'PRJ-2018-0000477'],
  ['createdOn', 'Mon Nov 19 18:48:02 IST 2018']]
 ],    
 ['createdBy=>>>BasicData',
  [['userId', '999996279'],    ['email', 'ITEST275@ITS.JNJ.com'],
  ['firstName', 'Iris'],    ['lastName', 'TEST275'],
  ['ntId', 'itest275'],    ['region', 'NA'],
  [' LastAccessTime ', ' 1542639905785 ']]
 ]
]

例外格式是

{
"key": "1542633482511430199",
"value=>>>BasicData": {
    "isConfirmAndOrder": "0",
    "brmRequestId": "BR-2018-0000124"
        .
},
"createdBy=>>>BasicData": {
    "userId": "999996279",
    "email": "ITEST275@ITS.JNJ.com"
        .
 }
        .
 }

实际上大数据的格式是:

[
 [
  ['key11','value11']
  ['key12',['key13','value13']]
  ['key14',['key15','value15']]
 ]
[
  ['key21','value21']
  ['key22',['key23','value23']]
  ['key24',['key25','value25']]
 ]
]

标签: pythonjson

解决方案


您可以为此编写一个简单的递归函数:

def to_dict_recursive(x):
    d = {}
    for key, value in x:
        if isinstance(value, list):
            value = to_dict_recursive(value)
        else:
            value = value.strip()  # get rid of unnecessary whitespace
        d[key.strip()] = value
    return d

to_dict_recursive(x)
# {'createdBy=>>>BasicData': {'displayName': 'Iris TEST275',
#   'email': 'ITEST275@ITS.JNJ.com',
#   'firstName': 'Iris',
#   'lastName': 'TEST275',
#   'ntId': 'itest275',
#   'region': 'NA',
#   'roles': '[0]CG510_DHF_AP_Role',
#   'userId': '999996279'},
#  'formulaDetails=>>>BasicData': {'CreationTime': '1542633482512',
#   'LastAccessTime': '1542639905785',
#   'batchSizeUnits': 'kg<<<<<<',
#   'hitCount': '1',
#   'version': '1'},
#  'key': '1542633482511430199',
#  'value=>>>BasicData': {'brmRequestId': 'BR-2018-0000124',
#   'createdMonth': 'Nov',
#   'createdOn': 'Mon Nov 19 18:48:02 IST 2018',
#   'department': 'Global Packaging',
#   'gxp': '1',
#   'id': '1542633482511430199',
#   'isConfirmAndOrder': '0',
#   'isFilling': 'false',
#   'projectId': 'PRJ-2018-0000477',
#   'projectName': 'Automation_Product_By_Admin',
#   'requestType': 'batch',
#   'status': 'New',
#   'statusDescription': 'Batch request created',
#   'updatedOn': 'Mon Nov 19 18:48:02 IST 2018'}}

(我在 Python 3.6 中运行它,因此字典表示中键的顺序与插入顺序不同。在 Python 3.7+ 中,这会有所不同。)

你甚至可以把它变成一个 dict 理解:

def to_dict_recursive(x):
    return {key.strip(): to_dict_recursive(value) if isinstance(value, list)
                         else value.strip
            for key, value in x}

由于对象中的某些元素显然不是键和值的两元素列表,因此您可以添加一个简单的防范措施:

def to_dict_recursive(x):
    d = {}
    try:
        for key, value in x:
            if isinstance(value, list):
                value = to_dict_recursive(value)
            else:
                value = value.strip()
            d[key.strip()] = value
    except ValueError:
        return x
    return d

x = [[' key ', ' 1542633482511430199'],
 ["test", ["a", "b", "c"]]
]
to_dict_recursive(x)
# {'key': '1542633482511430199', 'test': ['a', 'b', 'c']}

推荐阅读