我想把一个列表的字符串拆分成(几乎)相等的块,但也要考虑字符串列表中的一个数字。示例:
def split(a, n):
k, m = divmod(len(a), n)
return (a[i*k+min(i, m):(i+1)*k+min(i+1, m)] for i in range(n))
l = ["string-1-1", "string-1-2", "string-2-1", "string-2-2", "string-2-3"]
chunks = 2
l_split = list(split(l, chunks))这导致了
[['string-1-1', 'string-1-2', 'string-2-1'], ['string-2-2', 'string-2-3']]然而,我希望得到以下结果:
[['string-1-1', 'string-1-2'], ['string-2-1', 'string-2-2', '-2-3']]因此,列表应该在N块的总量中被拆分,但是只有在第一个位置上的数字(N-N)到达下一个值之后才会发生拆分。字符串中的数字可以是多个数字(例如12-24),但永远只能是2个数字(例如N-N)。
发布于 2022-07-14 17:34:49
您的解释尚不清楚,但我理解您希望根据给定的块大小将列表拆分为子列表。
所以,你不需要分配。我不确定,但这可能对你有帮助
[a[i:i + n] for i in range(0, len(a), n)]https://stackoverflow.com/questions/72984285
复制相似问题