python字典串列清洗器
場景
在寫api的時候, 很多資料來源于第三方, 原始API介面回傳的資料很多并不是我們想要的, 我們需要對原始資料進行篩選.
示例
-
原始資料如下
原始資料 = [ { 'OS-FLV-DISABLED:disabled': False, 'OS-FLV-EXT-DATA:ephemeral': 0, 'disk': 50, 'ephemeral': 0, 'extra_specs': Munch({}), 'id': 'abb677c9-1bf2-415d-97bd-ef62574690ed', 'is_disabled': False, 'is_public': True, 'location': {'cloud': '43.254.45.115', 'project': {'domain_id': None, 'domain_name': None, 'id': '3fb8e4b969eb4db8a67a6d576fc2070c', 'name': None}, 'region_name': None, 'zone': None}, 'name': 'wangjw', 'os-flavor-access:is_public': True, 'properties': {'OS-FLV-DISABLED:disabled': False, 'OS-FLV-EXT-DATA:ephemeral': 0, 'os-flavor-access:is_public': True}, 'ram': 4096, 'rxtx_factor': 1.0, 'swap': 0, 'vcpus': 2 }, ... ] -
我們只需要如下欄位
所需欄位 = ["name", "id", "ram", "vcpus", "disk", "is_disabled", "is_public"] -
最終結果
最終結果 =[ { 'disk': 50, 'id': 'abb677c9-1bf2-415d-97bd-ef62574690ed', 'is_disabled': False, 'is_public': True, 'name': 'wangjw', 'ram': 4096, 'vcpus': 2 }, ... ]
實作
代碼如下
#!/usr/bin/env python
# ~*~ coding: utf-8 ~*~
def map_clean(source_key_list, dict):
"""清洗字典
:param source_key:目標查找欄位
:param dict: 目標字典
:return:清洗后的字典
"""
tmp = {}
for k, v in dict.items():
if k in source_key_list:
tmp[k] = v
else:
continue
return tmp
if __name__ == "__main__":
source_key_list = ["name", "id", "ram", "vcpus", "disk", "is_disabled", "is_public"]
dict = 原始資料
最終資料 = map_clean(source_key_list, dict)
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/147673.html
標籤:Python
上一篇:python重試次數裝飾器
下一篇:python字典串列過濾器
