我有以下字典,
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] 删除。
我来说两句