在上一篇文章里面,我们讲到了如何使用Python的yield
关键字简化代码,压平多层嵌套字典的。
那么如果我们的数据不仅仅有字典,还有列表,是一个字典列表多层嵌套的数据怎么办呢?例如:
1 2 3 4 5 6 7 8 9 10 11 12
| nest_dict = { 'a': 1, 'b': { 'c': 2, 'd': 3, 'e': {'f': 4} }, 'g': {'h': 5}, 'i': 6, 'j': {'k': {'l': {'m': 8}}}, 'n': [1, {'o': 1, 'p': [1, 2, 3], 'q': {'r': {'s': 100}}}, 3, [1, 2, 3], 5] }
|
现在,请停下来,敲一敲代码,想想如何把处理列表的逻辑添加进去。
首先,我们来看一下最终被压平以后的数据长什么样:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
| {'a': 1, 'b_c': 2, 'b_d': 3, 'b_e_f': 4, 'g_h': 5, 'i': 6, 'j_k_l_m': 8, 'n_0': 1, 'n_1_o': 1, 'n_1_p_0': 1, 'n_1_p_1': 2, 'n_1_p_2': 3, 'n_1_q_r_s': 100, 'n_2': 3, 'n_3_0': 1, 'n_3_1': 2, 'n_3_2': 3, 'n_4': 5}
|
对于'n': ['a', 'b', 'c']
这种形式的数据,我们把它转换为: {'n_0': 'a', 'n_1': 'b', 'n_2': 'c'}