我有 2 个查询,您可以找到如下打印结果。
<QuerySet [{'swtype': 1}, {'swtype': 2}]>
<QuerySet ['201;203;205', '207;208']>
我在 stackoverflow 上查看了一些命令,用于按照以下方式对这些列表进行配对。
pair = itertools.zip_longest(swtype, p_list)
但是输出不是我想要的。好像是
1:201
2:203
none:205
none:207
none:208
我追求的是:
1:201
none:203
none:205
2:207
none:208
这是否可能通过压缩或我应该创建 2 个单独的循环。 如果我创建了 2 个单独的循环,那么我就会遇到其他问题。
最佳答案
我认为您对第二个查询集做了一些处理,用分号 (;
) 将其拆分为子字符串。这样做的问题是结构会丢失,因此您 zip
就好像它们总是独立的元素一样。但是,您可以保留结构并使用:
from itertools import chain, zip_longest
qs1 = [{'swtype': 1}, {'swtype': 2}] # first queryset
qs2 = ['201;203;205', '207;208'] # second queryset
result = chain.from_iterable(
zip_longest((qi1['swtype'],), qi2.split(';')) for qi1, qi2 in zip(qs1, qs2)
)
因此,我们在这里迭代两个查询集 qi1
和qi2
,然后我们执行一个zip_longest
qi1[swtype]
(包装成一个单例元组,因为我们需要一个可迭代对象,我们将 qi2
的字符串拆分为 的子字符串qi2.split(';')
).然后我们将“subzips”链接
在一起。
但是请注意,如果这两个查询集源自相似的查询,我建议您将这两个查询合并为一个。这更安全,因为它保证顺序匹配,而且通常(有一些异常(exception)),它也更有效。
关于python - django zip 不等列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51478288/