gpt4 book ai didi

python - django zip 不等列表

转载 作者:太空宇宙 更新时间:2023-11-04 02:21:35 25 4
gpt4 key购买 nike

我有 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)
)

因此,我们在这里迭代两个查询集 qi1qi2,然后我们执行一个zip_longest qi1[swtype](包装成一个单例元组,因为我们需要一个可迭代对象,我们将 qi2 的字符串拆分为 的子字符串qi2.split(';')).然后我们将“subzips链接在一起。

但是请注意,如果这两个查询集源自相似的查询,我建议您将这两个查询合并为一个。这更安全,因为它保证顺序匹配,而且通常(有一些异常(exception)),它也更有效。

关于python - django zip 不等列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51478288/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com