在字典值的条件之后重新排序或重新创建字典键 -

用户9431057

我有以下字典,

test_dict = {1: 'Okay', 2: 'not good', 3: 'not well', 4: 'fine'}

由此,我想检查一个值的长度是否大于 4,如果是,则将其拆分为大小均匀的块。一旦块发生,我想添加一个键并为这些块赋值。例如,输出如下:

out_dict = {1:'Okay', 2: 'not ', 3: 'good', 4: 'not ', 5: 'well', 6: 'fine'}

如果您看到因为test_dict的键 2 和 3 的字符串大于 4,则它们会被拆分,并且每个拆分都应获得自己的键和拆分值作为键 2、3、4、5 的值。

这是我迄今为止尝试过的,

list_of_no_change = []
list_of_changed_dicts = []

for k, v in test_dict.items():    
    no_change = {}
    temp_dict = {}
    
    if len(v) > 4:
        # Divide into chunks
        chunks = [v[i:i + 4] for i in range(0, len(v), 4)]
        
        k_increment = 1
        
        for ix, vl in enumerate(chunks):
            
            if ix == 0:
                temp_dict[k] = vl
                
            else:
                new_k = k + k_increment
#                 print('Senetence id::>>>',ix, 'Value::>>>',vl, 'new key value::>>>',new_k)
                temp_dict[new_k] = vl
                k_increment +=1
        
    else:
        no_change[k] = v
        
    list_of_changed_dicts.append(temp_dict)
    list_of_no_change.append(no_change)

我从两个列表中得到的输出,与我要去的地方不接近:(

list_of_no_change - [{1: 'Okay'}, {}, {}, {4: 'fine'}]
list_of_changed_dicts - [{}, {2: 'not ', 3: 'good'}, {3: 'not ', 4: 'well'}, {}]

实现我的输出的任何帮助/建议都会很棒。

温德雷亚

我不确定这两个列表的目的是什么,但主要问题是您根本没有正确计算。解决此问题的最简单方法是无条件分块,然后使用enumerate()构建输出。

chunks = (v[i:i+4] for v in test_dict.values() for i in range(0, len(v), 4))
out_dict = {i: s for i, s in enumerate(chunks, 1)}
# {1: 'Okay', 2: 'not ', 3: 'good', 4: 'not ', 5: 'well', 6: 'fine'}

这里我做chunks了一个生成器表达式来避免构造一个列表。

我假设您使用的是 Python 3.7+,其中 dicts 保留插入顺序。如果没有,您可以替换test_dict.values()(test_dict[k] for k in sorted(test_dict)).

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章