蟒蛇加入子字典

时间:2020-05-20 08:49:00

标签: python json dictionary

我正在尝试在python中加入子词,以便组成有效的json 我所拥有的是:

{
'ctx/language': 'en',
'ctx/territory': 'DE',
'composer_name': 'openEHR2study',
'Allergies': {
    'adverse_reaction-allergy': [{
            'reaction_event_summary': {
                'clinical_impact': [{
                        '|code': 'at0035'
                    }
                ]
            }
        }, {
            'recorded': ['2020-05-14T00:00:00.000Z']
        }, {
            'reaction_event_summary': {
                'certainty': [{
                        '|code': 'at0024'
                    }
                ]
            }
        }, {
            'substance_agent': ['s']
        }, {
            'reaction_reported': ['true']
        }, {
            'comment': ['c']
        }
    ]
}

}

我想要的是像这样通过“ reaction_event_summary”进行联接:

{
'ctx/language': 'en',
'ctx/territory': 'DE',
'composer_name': 'openEHR2study',
'Allergies': {
    'adverse_reaction-allergy': [{
            'reaction_event_summary': {
                'clinical_impact': [{
                        '|code': 'at0035'
                    }
                ]
                 'certainty': [{
                        '|code': 'at0024'
                    }
                ]
            }
        }, {
            'recorded': ['2020-05-14T00:00:00.000Z']
        }, {
            'substance_agent': ['s']
        }, {
            'reaction_reported': ['true']
        }, {
            'comment': ['c']
        }
    ]
}

我不知道该如何遍历json / list和字典来完成此工作。

1 个答案:

答案 0 :(得分:1)

我进行了粗略的尝试,请检查是否可行。我们正在尝试使用另一个Deepcopy迭代字典。


val = {
    'ctx/language': 'en',
    'ctx/territory': 'DE',
    'composer_name': 'openEHR2study',
    'Allergies': {
        'adverse_reaction-allergy': [
            {
                'reaction_event_summary': {
                    'clinical_impact': [{
                        '|code': 'at0035'
                    }
                    ]
                }
            }, {
                'recorded': ['2020-05-14T00:00:00.000Z']
            }, {
                'reaction_event_summary': {
                    'certainty': [{
                        '|code': 'at0024'
                    }
                    ]
                }
            }, {
                'substance_agent': ['s']
            }, {
                'reaction_reported': ['true']
            }, {
                'comment': ['c']
            }
        ]
    }
}

import copy

val1 = copy.deepcopy(val)
del val1['Allergies']['adverse_reaction-allergy']
val1['Allergies']['adverse_reaction-allergy'] = []
reaction_count = 0

for _d in val['Allergies']['adverse_reaction-allergy']:
    if _d.get('reaction_event_summary', False):
        if reaction_count < 1:
            reaction_count += 1
            val1['Allergies']['adverse_reaction-allergy'].append(
                {'reaction_event_summary': _d.get('reaction_event_summary')})
        else:
            print(_d.get('reaction_event_summary'))
            _temp = val1['Allergies']['adverse_reaction-allergy'][0]['reaction_event_summary']
            _temp['certainty'] = _d.get('reaction_event_summary',{}).get('certainty',{})
            val1['Allergies']['adverse_reaction-allergy'][0]['reaction_event_summary'] = _temp
    else:
        val1['Allergies']['adverse_reaction-allergy'].append(_d)
import json
print(json.dumps(val1, indent=2))

示例输出

{
  "ctx/language": "en",
  "ctx/territory": "DE",
  "composer_name": "openEHR2study",
  "Allergies": {
    "adverse_reaction-allergy": [
      {
        "reaction_event_summary": {
          "clinical_impact": [
            {
              "|code": "at0035"
            }
          ],
          "certainty": [
            {
              "|code": "at0024"
            }
          ]
        }
      },
      {
        "recorded": [
          "2020-05-14T00:00:00.000Z"
        ]
      },
      {
        "substance_agent": [
          "s"
        ]
      },
      {
        "reaction_reported": [
          "true"
        ]
      },
      {
        "comment": [
          "c"
        ]
      }
    ]
  }
}