Python 如何使用pprint在新列表中保存部分列表?

Python 如何使用pprint在新列表中保存部分列表?,python,list,pprint,Python,List,Pprint,我尝试使用Python将列表分成相等的部分。因为我想重用输出,所以我想用零件创建新的列表 在这方面,stackoverflow有很多问题。我决定使用pprint l = list(range(100)) n = 15 def chunks(l, n): """Yield successive n-sized chunks from l.""" for i in range(0, len(l), n): yield l[i:i + n] import pprint

我尝试使用Python将列表分成相等的部分。因为我想重用输出,所以我想用零件创建新的列表

在这方面,stackoverflow有很多问题。我决定使用pprint

l = list(range(100))
n = 15
def chunks(l, n):
    """Yield successive n-sized chunks from l."""
    for i in range(0, len(l), n):
        yield l[i:i + n]
import pprint
pprint.pprint(list(chunks(list(range(0, 100)), 10)))
实际结果如下:

[[0, 1, 2, 3, 4, 5, 6, 7, 8, 9],
 [10, 11, 12, 13, 14, 15, 16, 17, 18, 19],
 [20, 21, 22, 23, 24, 25, 26, 27, 28, 29],
 ]
等等

我期望像这样的输出

list1 = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
list2 = [10, 11, 12, 13, 14, 15, 16, 17, 18, 19]
等等


->如何自动创建此类列表?我不想手动为列表的名称编号。

似乎您已经拥有了所需的内容。 如果您执行以下操作:

my_lists = list(chunks(list(range(0, 100)), 10))
我的列表[0]->列表1 . .


我的列表[n]->listn

您可以解压缩列表:

l = list(range(100))
n = 15
def chunks(l, n):
    """Yield successive n-sized chunks from l."""
    for i in range(0, len(l), n):
        yield l[i:i + n]
import pprint

res = (list(chunks(list(range(0, 100)), 10)))
lstA, lstB, lstC, lstD, lstE, lstF, lstG, lstH, lstI, lstJ = [*res]

pprint.pprint(lstA)
pprint.pprint(lstB)
输出

[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
[10, 11, 12, 13, 14, 15, 16, 17, 18, 19]
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
[10, 11, 12, 13, 14, 15, 16, 17, 18, 19]

如果您不保存它们:

print(res[0])
print(res[1])
输出

[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
[10, 11, 12, 13, 14, 15, 16, 17, 18, 19]
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
[10, 11, 12, 13, 14, 15, 16, 17, 18, 19]

如果您只是在寻找打印块的方法,可以使用一个带有跨步范围的简单循环:

l = list(range(100))
n = 10
for i in range(0,len(l),n): 
    print(f"list{1+i//n} = {l[i:i+n]}")

# output:
list1 = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
list2 = [10, 11, 12, 13, 14, 15, 16, 17, 18, 19]
list3 = [20, 21, 22, 23, 24, 25, 26, 27, 28, 29]
list4 = [30, 31, 32, 33, 34, 35, 36, 37, 38, 39]
list5 = [40, 41, 42, 43, 44, 45, 46, 47, 48, 49]
list6 = [50, 51, 52, 53, 54, 55, 56, 57, 58, 59]
list7 = [60, 61, 62, 63, 64, 65, 66, 67, 68, 69]
list8 = [70, 71, 72, 73, 74, 75, 76, 77, 78, 79]
list9 = [80, 81, 82, 83, 84, 85, 86, 87, 88, 89]
list10 = [90, 91, 92, 93, 94, 95, 96, 97, 98, 99]
如果需要实际变量(list1、list2,…),可以在循环中使用exec(),但在程序的其余部分中很难使用(与列表列表相反):


你可能会问自己,为什么要这样做,因为列表列表是一种比10个单独命名的列表更易于管理的数据结构。为什么要
list2=[20,21,22,23,24,25,26,27,28,29]
而不是
list2=[10,11,12,13,14,15,16,17,18,19]
?@Chris我有大量的数据
l
实际上是20万项中2500万位的列表。我必须进一步处理数据,所以我认为最好在单独的列表中分离项目。根据您的评论,我认为最好是解决列表中的部分。我不知道这种可能性。非常感谢。@AlainT这是一个典型的文字错误。谢谢你敏锐的眼睛。我编辑了这篇文章。这听起来很优雅。你说的“如果你不拯救他们”是什么意思?这听起来很有趣。您的意思是,我不必使用pprint来解决我的问题。我一定会试试的。谢谢。pprint仅帮助您以方便的方式打印阵列。如果您想使用它,但如果您想访问每个列表,只需将其存储在如上所示的列表中即可。您很好地假设我正在寻找打印块的方法。你的第一个例子非常优雅地说明了这一点。非常感谢。这正是我想要的。
listOfLists[0] is same as list1
listOfLists[1] is same as list2 
...
listOfLists[K-1] is same as listK