python - 加入两个具有相同值和不同键的字典列表
问题描述
请在没有 pandas 或 numpy 的情况下解决需要解决的问题。我有两个字典列表,即 list1 和 list2。我需要按“post_code”对 list2 进行排序,并在通过两个具有相同值的不同键加入 list1 和 list2 之前按“code”对排序后的 list2 进行分组。在 list1 中,键“practice”等价于排序后的 list2 中的键“code”。我需要通过“实践”和“代码”的等效键加入list1和list2。
list1=
[{'bnf_code': '0101010G0AAABAB',
'items': 2,
'practice': 'N81013',
'bnf_name': 'Co-Magaldrox_Susp 195mg/220mg/5ml S/F',
'nic': 5.98,
'act_cost': 5.56,
'quantity': 1000},
{'bnf_code': '0101021B0AAAHAH',
'items': 1,
'practice': 'A81001',
'bnf_name': 'Alginate_Raft-Forming Oral Susp S/F',
'nic': 1.95,
'act_cost': 1.82,
'quantity': 500},
{'bnf_code': '0101021B0AAALAL',
'items': 12,
'practice': 'A81002',
'bnf_name': 'Sod Algin/Pot Bicarb_Susp S/F',
'nic': 64.51,
'act_cost': 59.95,
'quantity': 6300},
{'bnf_code': '0101021B0AAAPAP',
'items': 3,
'practice': 'A81004',
'bnf_name': 'Sod Alginate/Pot Bicarb_Tab Chble 500mg',
'nic': 9.21,
'act_cost': 8.55,
'quantity': 180},
{'bnf_code': '0101021B0BEADAJ',
'items': 6,
'practice': 'A81003',
'bnf_name': 'Gaviscon Infant_Sach 2g (Dual Pack) S/F',
'nic': 28.92,
'act_cost': 26.84,
'quantity': 90}]
list2=
[{'code': 'A81001',
'name': 'THE DENSHAM SURGERY',
'addr_1': 'THE HEALTH CENTRE',
'addr_2': 'LAWSON STREET',
'borough': 'STOCKTON ON TEES',
'village': 'CLEVELAND',
'post_code': 'TS18 1HU'},
{'code': 'A81002',
'name': 'QUEENS PARK MEDICAL CENTRE',
'addr_1': 'QUEENS PARK MEDICAL CTR',
'addr_2': 'FARRER STREET',
'borough': 'STOCKTON ON TEES',
'village': 'CLEVELAND',
'post_code': 'TS18 2AW'},
{'code': 'A81003',
'name': 'VICTORIA MEDICAL PRACTICE',
'addr_1': 'THE HEALTH CENTRE',
'addr_2': 'VICTORIA ROAD',
'borough': 'HARTLEPOOL',
'village': 'CLEVELAND',
'post_code': 'TS26 8DB'},
{'code': 'A81004',
'name': 'WOODLANDS ROAD SURGERY',
'addr_1': '6 WOODLANDS ROAD',
'addr_2': None,
'borough': 'MIDDLESBROUGH',
'village': 'CLEVELAND',
'post_code': 'TS1 3BE'},
{'code': 'N81013',
'name': 'SPRINGWOOD SURGERY',
'addr_1': 'SPRINGWOOD SURGERY',
'addr_2': 'RECTORY LANE',
'borough': 'GUISBOROUGH',
'village': None,
'post_code': 'TS14 7DJ'}]
我已经能够按 post_code 对 list2 进行排序并按代码分组,但我对如何加入 list1 和 list2 感到迷茫。这是我迄今为止用于排序和分组的代码。
import itertools
from operator import itemgetter
sorted_post_code = sorted(list2, key=itemgetter('post_code'))
for key, group in itertools.groupby(sorted_post_code, key=lambda x:x['code']):
#print (key),
print (list(group))
预期输出为
joined_list=
list1=
[{'bnf_code': '0101010G0AAABAB',
'items': 2,
'practice': 'N81013',
'bnf_name': 'Co-Magaldrox_Susp 195mg/220mg/5ml S/F',
'nic': 5.98,
'act_cost': 5.56,
'quantity': 1000,
'code': 'N81013',
'name': 'SPRINGWOOD SURGERY',
'addr_1': 'SPRINGWOOD SURGERY',
'addr_2': 'RECTORY LANE',
'borough': 'GUISBOROUGH',
'village': None,
'post_code': 'TS14 7DJ'},
{'bnf_code': '0101021B0AAAHAH',
'items': 1,
'practice': 'A81001',
'bnf_name': 'Alginate_Raft-Forming Oral Susp S/F',
'nic': 1.95,
'act_cost': 1.82,
'quantity': 500,
'code': 'A81001',
'name': 'THE DENSHAM SURGERY',
'addr_1': 'THE HEALTH CENTRE',
'addr_2': 'LAWSON STREET',
'borough': 'STOCKTON ON TEES',
'village': 'CLEVELAND',
'post_code': 'TS18 1HU'},
{'bnf_code': '0101021B0AAALAL',
'items': 12,
'practice': 'A81002',
'bnf_name': 'Sod Algin/Pot Bicarb_Susp S/F',
'nic': 64.51,
'act_cost': 59.95,
'quantity': 6300,
'code': 'A81002',
'name': 'QUEENS PARK MEDICAL CENTRE',
'addr_1': 'QUEENS PARK MEDICAL CTR',
'addr_2': 'FARRER STREET',
'borough': 'STOCKTON ON TEES',
'village': 'CLEVELAND',
'post_code': 'TS18 2AW'},
{'bnf_code': '0101021B0AAAPAP',
'items': 3,
'practice': 'A81004',
'bnf_name': 'Sod Alginate/Pot Bicarb_Tab Chble 500mg',
'nic': 9.21,
'act_cost': 8.55,
'quantity': 180,
'code': 'A81004',
'name': 'WOODLANDS ROAD SURGERY',
'addr_1': '6 WOODLANDS ROAD',
'addr_2': None,
'borough': 'MIDDLESBROUGH',
'village': 'CLEVELAND',
'post_code': 'TS1 3BE'},
{'bnf_code': '0101021B0BEADAJ',
'items': 6,
'practice': 'A81003',
'bnf_name': 'Gaviscon Infant_Sach 2g (Dual Pack) S/F',
'nic': 28.92,
'act_cost': 26.84,
'quantity': 90,
'code': 'A81003',
'name': 'VICTORIA MEDICAL PRACTICE',
'addr_1': 'THE HEALTH CENTRE',
'addr_2': 'VICTORIA ROAD',
'borough': 'HARTLEPOOL',
'village': 'CLEVELAND',
'post_code': 'TS26 8DB'}]
解决方案
我了解您希望 list1 中的每个字典都包含 list2 中字典的所有条目,如果字典的键“代码”和“实践”的值匹配。
如果是这样,您可以轻松地使用另一个字典中的条目更新字典的所有条目。缺少的键:值对将被添加,现有的键将更新它们的值。
所以我最终得到了一个双 for 循环,这是我在任何排序之前所做的。您可能需要根据自己的需要进行调整。
for entry2 in list2:
for entry1 in list1:
if entry2['code'] == entry1['practice']:
entry1.update(entry2)
关于加入字典的不同方法的很长的解释可以在这里找到:https ://stackoverflow.com/a/26853961/6218902
推荐阅读
- .net - Windows 服务的关闭行为和变量的生命周期
- reactjs - Ag-Grid-React 不是以表格格式呈现数据
- swift - 使用 Firebase 时命令 PhaseScriptExecution 失败并出现非零退出代码错误
- java - 如何将(非 android)Java 应用程序连接到 Firebase 存储并上传文件?
- c# - Binding Property in command parameter (datagrid)
- android - 使用 refreshcontroll 和无限负载反应本机绑定滚动视图以自动隐藏标题
- java - Testing @ControllerAdvice with MockMvc Http Status error
- flutter - 更新 android studio 3.6.3 并颤动后,它给了我一个错误,即找不到或加载主类 com.android.sdklib.tool.sdkmanager.SdkManagerCli
- android - Android Material ButtonToggleGroup get checkedButtonId
- html - 图像未使用内联 CSS 在 HTML 页面的中心对齐