我只想为列表中的每个元素获取相同的索引字母

I just want to get same index letter for each element on my list

例如:

a = "pandaxngeqrymtso-ezmlaesowxaqbujl-noilktxreecytrql-gskaboofsfoxdtei-utsmakotufodhlrd-iroachimpanzeesa-nintrwflyrkhcdum-jcecahkktiklsvhr-mhvsbaykagodwgca-koalatcwlkfmrwbb-jsrrfdolphinuyt"

a = a.split("-") 

mylist = []

word = ""

while i < len(a[0]): #16

      for elem in a:
        word+= elem[i]
  mylist.append(kelime)

  i += 1

  word = "" 

我只想要一个包含 "penguinjmhkj, azostrichos..." 的列表,但出现索引错误。 我能做什么?

你可以试试这个:

>>> word = [''.join(letters) for letters in zip(*(list(word) for word in a.split('-')))]
>>> word
['penguinjmkj',
 'azostrichos',
 'nmiksonevar',
 'dllamatcslr',
 'aakbacrabaf',
 'xetokhwhatd',
 'nsxooifkyco',
 'gorftmlkkwl',
 'ewesupytalp',
 'qxeffarigkh',
 'racoonkkofi',
 'yqyxdzhldmn',
 'mbtdhecswru',
 'turtledvgwy',
 'sjqersuhcbt']

说明: 如果您打印各个部分,您可以了解它在做什么, 例如:

>>> print(*(list(word) for word in a.split('-'))
['p', 'a', 'n', 'd', 'a', 'x', 'n', 'g', 'e', 'q', 'r', 'y', 'm', 't', 's', 'o'] ['e', 'z', 'm', 'l', 'a', 'e', 's', 'o', 'w', 'x', 'a', 'q', 'b', 'u', 'j', 'l'] ['n', 'o', 'i', 'l', 'k', 't', 'x', 'r', 'e', 'e', 'c', 'y', 't', 'r', 'q', 'l'] ['g', 's', 'k', 'a', 'b', 'o', 'o', 'f', 's', 'f', 'o', 'x', 'd', 't', 'e', 'i'] ['u', 't', 's', 'm', 'a', 'k', 'o', 't', 'u', 'f', 'o', 'd', 'h', 'l', 'r', 'd'] ['i', 'r', 'o', 'a', 'c', 'h', 'i', 'm', 'p', 'a', 'n', 'z', 'e', 'e', 's', 'a'] ['n', 'i', 'n', 't', 'r', 'w', 'f', 'l', 'y', 'r', 'k', 'h', 'c', 'd', 'u', 'm'] ['j', 'c', 'e', 'c', 'a', 'h', 'k', 'k', 't', 'i', 'k', 'l', 's', 'v', 'h', 'r'] ['m', 'h', 'v', 's', 'b', 'a', 'y', 'k', 'a', 'g', 'o', 'd', 'w', 'g', 'c', 'a'] ['k', 'o', 'a', 'l', 'a', 't', 'c', 'w', 'l', 'k', 'f', 'm', 'r', 'w', 'b', 'b'] ['j', 's', 'r', 'r', 'f', 'd', 'o', 'l', 'p', 'h', 'i', 'n', 'u', 'y', 't']

因此它将所有由 - 分隔的单个单词分解为字符。 然后 zip 这样做:

>>> print(zip(*(list(word) for word in a.split('-'))))
('p', 'e', 'n', 'g', 'u', 'i', 'n', 'j', 'm', 'k', 'j') ('a', 'z', 'o', 's', 't', 'r', 'i', 'c', 'h', 'o', 's') ('n', 'm', 'i', 'k', 's', 'o', 'n', 'e', 'v', 'a', 'r') ('d', 'l', 'l', 'a', 'm', 'a', 't', 'c', 's', 'l', 'r') ('a', 'a', 'k', 'b', 'a', 'c', 'r', 'a', 'b', 'a', 'f') ('x', 'e', 't', 'o', 'k', 'h', 'w', 'h', 'a', 't', 'd') ('n', 's', 'x', 'o', 'o', 'i', 'f', 'k', 'y', 'c', 'o') ('g', 'o', 'r', 'f', 't', 'm', 'l', 'k', 'k', 'w', 'l') ('e', 'w', 'e', 's', 'u', 'p', 'y', 't', 'a', 'l', 'p') ('q', 'x', 'e', 'f', 'f', 'a', 'r', 'i', 'g', 'k', 'h') ('r', 'a', 'c', 'o', 'o', 'n', 'k', 'k', 'o', 'f', 'i') ('y', 'q', 'y', 'x', 'd', 'z', 'h', 'l', 'd', 'm', 'n') ('m', 'b', 't', 'd', 'h', 'e', 'c', 's', 'w', 'r', 'u') ('t', 'u', 'r', 't', 'l', 'e', 'd', 'v', 'g', 'w', 'y') ('s', 'j', 'q', 'e', 'r', 's', 'u', 'h', 'c', 'b', 't')

所以它从每个组中获取所有相应的字符,每个元组在主代码的每次迭代中都作为 letters 传递。 然后你 join 每个元组,例如在第一次迭代中:

>>> ''.join(('p', 'e', 'n', 'g', 'u', 'i', 'n', 'j', 'm', 'k', 'j'))
'penguinjmkj'

[<item after some operation> for <each item> in <item_list>]这个结构叫做list comprehension. * is used for iterable unpacking.

花了点时间终于破解了;

您只需要处理索引错误:字符串超出范围。

如果你算的话他们超过了16个,而拆分后的数组项刚好超过11个。长话短说;使用 try_except 处理异常,您将在以下位置附加字母:

 word+= elem[i]

这是我的代码以及我是如何使用 try_catch

解决它的
a = "pandaxngeqrymtso-ezmlaesowxaqbujl-noilktxreecytrql-gskaboofsfoxdtei-utsmakotufodhlrd-iroachimpanzeesa-nintrwflyrkhcdum-jcecahkktiklsvhr-mhvsbaykagodwgca-koalatcwlkfmrwbb-jsrrfdolphinuyt"
newArr = a.split('-')
newWord = []
i = 0
mylist = []
while i < len(newArr[0]):
    word = ""
    for item in newArr:
       try:
            word  += item[i]
       except:
            break
    i += 1
    mylist.append(word)
print(mylist)


我在附加字母时使用 try_except 来处理索引错误,然后在用于 while 循环的 'i' 大于 for 循环中的 newArr 长度时中断。

为自己努力!

与 Sayandip 的代码类似,但过去对我来说可读性更好:

mylist =[]

for element in zip(*a.split('-')):
    mylist.append(''.join(element))

print(mylist)

我明白了

['penguinjmkj', 'azostrichos', 'nmiksonevar', 'dllamatcslr', 'aakbacrabaf', 'xetokhwhatd', 'nsxooifkyco', 'gorftmlkkwl', 'ewesupytalp', 'qxeffarigkh', 'racoonkkofi', 'yqyxdzhldmn', 'mbtdhecswru', 'turtledvgwy', 'sjqersuhcbt']

我正在 for 循环中移动拆分,并使用 * 构造传递拆分产生的整个列表,请参阅用法 here and here