簡體   English   中英

如何使用python將包含鍵值對的嵌套列表轉換為json格式

[英]how to convert nested list which contain key - value pair to json format using python

我有['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']]
 ]
]

您可以為此編寫一個簡單的遞歸函數:

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+中,此順序將有所不同。)

您甚至可以將其轉化為字典理解:

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']}

請注意,如果mylist是鍵值對列表,那么dict(mylist)只會返回其字典版本。 棘手的部分是遍歷這些嵌套列表,以用字典替換它們。 這是執行此操作的遞歸函數:

# Where <kv> is your giant list-of-lists.
def kv_to_dict(kv):
    if isinstance(kv, list):
        kv = dict(kv)
    for k in kv:
        if isinstance(kv[k], list):
            kv[k] = kv_to_dict(kv[k])
    return kv

newdict = kv_to_dict(kvpairs)

將內容轉換為字典后,只需使用json.dumps()將其格式化為JSON:

import json
as_json = json.dumps(newdict, indent=4)
print(as_json)

我發現您嘗試過類似的操作並收到錯誤消息。 您確定數據中的所有列表都是真正的鍵值對,而不是例如3個字符串的列表嗎?

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM