如何动态创建字典?

时间:2019-11-11 21:05:10

标签: python-3.x list dictionary

假设我有一个函数返回一个名为get_miles_sum_by_region()的数值。它包含几个参数(区域,层,study_type):

region = 1
reg_tier1_approx = get_miles_sum_by_region(region, 'TIER 1', 'Approximate')
reg_tier2_approx = get_miles_sum_by_region(region, 'TIER 2', 'Approximate')
reg_tier3_approx = get_miles_sum_by_region(region, 'TIER 3', 'Approximate')
reg_tier4_approx = get_miles_sum_by_region(region, 'TIER 4', 'Approximate')
reg_tier1_detailed = get_miles_sum_by_region(region, 'TIER 1', 'Detailed')
reg_tier2_detailed = get_miles_sum_by_region(region, 'TIER 2', 'Detailed')
reg_tier3_detailed = get_miles_sum_by_region(region, 'TIER 3', 'Detailed')
reg_tier4_detailed = get_miles_sum_by_region(region, 'TIER 4', 'Detailed')

基本上,我想创建一个像这样的字典:

region_dict = {1: {'Detailed': {'Tier1': 123.547, 'Tier2': 69.6,...}, 'Approximate': {'Tier1': 459.0032, 'Tier2': 540.112,...} } }

我尝试使用setdefault(),但设置不正确:

region_dict = dict()
region_dict.setdefault(region, list('Detailed')).append(reg_tier1_detailed)

关于正确设置此设置的任何建议吗?

1 个答案:

答案 0 :(得分:1)

我不确定dict.setdefault在这种情况下如何工作,但是我知道您可以使用嵌套的dict理解:

region_dict = {
    region: {
        study_type: {
            f'Tier {i}':
            get_miles_sum_by_region(region, f'TIER {i}', study_type)
            for i in range(1, 5)
            }
        for study_type in ['Detailed', 'Approximate']
        }
    for region in [1]
    }