簡體   English   中英

如何在 python 中創建可索引的空列表?

[英]How do you create an indexable empty list in python?

有沒有辦法在 python 中巧妙地創建大型(即可索引)空列表?

這就是我目前正在做的事情:

firstgen=G.neighbors(node1)
secgen=[]
thirdgen=[[],[],[],[],[],[],[],[],[],[],[]]  #11 brackets because len(secgen)=11

for i in firstgen:
    secgen.append(G.neighbors(i))   

for i in range(len(secgen)):
    for j in secgen[i]:
        thirdgen[i].append(G.neighbors(j))

我正在做的是找到網絡中原始節點的鄰居的鄰居的鄰居,因此我的第三代鄰居列表應該具有結構 [[[...],[...],[.. .]], [[...],[...],[...]], [[...],[...],[...]] ] 但我是 python 的新手並且如果不手動輸入thirdgen的長度,就無法找到如何完成這項工作。

對不起,令人困惑的解釋。 我這樣做是為了在網絡中找到三元組,即如果任何第三代節點與初始節點相同,那么我找到了三元組。

謝謝!

編輯:我剛剛意識到我可以簡單地將thirdgen.append([])放在第一個循環中。 不過仍然對其他方法感到好奇。

您不需要創建空列表。 您可以使用列表推導來構建嵌套列表:

firstgen = G.neighbors(node1)
secndgen = [G.neighbors(node) for node in firstgen]
thirdgen = [[G.neighbors(node) for node in group] for group in secndgen]
  • firstgen: [node, ...]
  • secndgen: [[node, ...], ...]
  • thirdgen: [[[node, ...], ...], ...]

也許:

thirdgen = [list() for x in range(len(secgen))]
thirdgen = [list() for x in range(11)]

或者我可能誤解了實際問題。

您可以按如下方式使用列表生成器: [[] for x in range(11)]

看看numpy

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM