
大佬们,下面这小段,有什么简写吗,已被自己蠢哭
# python3 A_one, A_other_one, A_two, A_other_two = A B_one, B_other_one, B_two, B_other_two = B ... # 会有很多 all = [ [{ "A_one": A_one, "B_one": B_one }, { "A_other": A_other_one, "B_other": B_other_one } ], [{ "A_one": A_two, "B_one": B_two }, { "A_other": A_other_two, "B_other": B_other_two } ] ] 1 paddistone 2020-11-13 16:35:28 +08:00 k 要是没有意义干嘛不考虑元组; 需求如此的话,这就是最好的实现了,keep simple, keep stupid ; 一点要花里胡哨一点,exec 、eval 了解一下,不建议 |
2 RRRoger 2020-11-13 16:38:03 +08:00 你至少得先把这些重复的东西 提取出一个函数吧 |
3 chaleaoch 2020-11-13 16:38:38 +08:00 你的意思 A 和 B 会有很多 成对出现吗? 否则你这个代码看不懂. |
4 tairan2006 2020-11-13 16:40:24 +08:00 你这是为了解包?你直接写个数组按索引取不就完了 |
5 xchaoinfo 2020-11-13 16:41:19 +08:00 试试这个模块 ```python from collections import namedtuple ``` |
6 MaxTan 2020-11-13 16:41:51 +08:00 没看懂为啥要这样写,先把思路捋清楚 |
7 css3 OP @css3 @paddistone @RRRoger @chaleaoch @tairan2006 @xchaoinfo @MaxTan 就是通过 A, B... 生成 all 这个 list, all 里边嵌套 list, 里边又是个 dict, dict 的 key 是固定的 |
8 css3 OP value 根据 A, B unpack 后的值,塞进来 |
9 tairan2006 2020-11-13 17:01:55 +08:00 就是按索引处理啊…all = [[] for _ in range(10)],然后遍历 A,把 A 的元素先塞到结果数组里,遍历 B 接着塞 |
10 acmore 2020-11-13 17:04:05 +08:00 `namedtuple` or `dataclass`? |
11 ysc3839 2020-11-13 17:05:19 +08:00 按照你给的代码中我发现的规律: data = {'A': [1,2,3,4], 'B': [5,6,7,8], 'C': [9,0,1,2]} all = [ [{f'{k}_one': v[0] for k, v in data.items()}, {f'{k}_other': v[1] for k, v in data.items()}], [{f'{k}_one': v[2] for k, v in data.items()}, {f'{k}_other': v[3] for k, v in data.items()}] ] |
12 imn1 2020-11-14 14:32:16 +08:00 既然 key 固定,变化不定的只是值,那很多解决办法 key 固定的,基本上从 sql 思维考虑就可以了,简单就 namedtuple 、csv,复杂就 pandas.DataFrame,sql 数据库 根据数据来源采用相应方便的方案,然后导出就可以了,可以用 iter() + append |
13 mizai 2020-11-15 23:33:23 +08:00 用 zip 加推导式很容易就可以简化 A = [1,2,3,4] B = ['a','b','c','d'] C = [random() for i in range(4)] data_array = [A,B,C] # 可以添加任意长度的数据 keys = ['one','other_one','two','other_two'] # dict 的 key 值固定 all = [dict(zip(column,data_item)) for data_item in zip(*data_array)] |
14 SjwNo1 2020-11-19 13:53:13 +08:00 zip |