gpt4 book ai didi

python - 如何多次循环访问相同的列表?

转载 作者:行者123 更新时间:2023-11-28 21:38:01 24 4
gpt4 key购买 nike

请耐心等待,我使用 Python 才两周时间。

我正在编写一个小项目,其中包括使用用户定义的 key 来加扰文本文件(字符串)。

例子:

String = "Monty"
Key = 1232

我做的第一件事就是把它分成字母,这样它们就变成了:

['m','o','n','','y'](所有字母小写)

['1','2','3','2']

到目前为止对我来说足够简单。我还有一个列表,其中包含 0-9 的所有英文字母和数字。

现在,加扰部分看起来像这样:

def encrypt0r(textList,keyList,letterList): #Encrypting the string using the key
encryptedList = []
encryptedStr = ""

for character in textList:
if character in letterList:
tempIndex = letterList.index(character) + 1 #THE 1 IS A PLACEHOLDER
encryptedList.append(letterList[tempIndex])

else:
encryptedList.append(character)
encryptedStr = "".join(encryptedList)
return encryptedStr

其中3个列表分别是我的字母列表、4位数字列表和所有英文字母和数字列表。

monty 的输出应该是这样的:

nqqvz

因为:

m + 1 = n 的索引

o + 2 = q 的索引

n + 3 = q 的索引

t + 2 = v 的索引

y + 1 = z 的索引 **注意当 keyList 已经结束时,它如何返回到 keyList 的开头。我怎样才能让它通过列表然后一旦它这样做一次,再次通过它。

如果有更快的步骤方法,我很想听听。我的脑海中不断出现 [0::4] - [3::4] 这些天赐的图像,但我不知道如何实现它。

我的第二个问题与我的第一个类似:

上面代码中的占位符只是为了检查我的程序是否在没有用户定义键的情况下实际工作。它确实如此,除非你告诉它通过信件列表。该列表以 [......,'8','9'] 结尾,因此 8 + 1 将被打乱为 9 但我希望 9 + 1 返回到同一列表的开头并打乱9作为“a”。我已经在互联网上搜索了 2 天,我终于屈服于在这里发帖。

在此先感谢您的帮助。只是要求你们保持行话/行话更容易理解,本质上是脚本小子(我),如果您有解决方案,请向我解释它是如何工作的,以便我可以在未来的项目中学习和使用它!

最佳答案

第 1 部分

输入中的每个字母都与键列表中的一个元素耦合。这意味着这是 zip 的工作(python 2 中的 izip):

for character, key in zip(textList, keyList):
# processing

问题是如果keyListtextList短,它会停在keyList的末尾。但是,itertools 中有一个很好的工具就是用于此目的:itertools.cycle:

for character, key in zip(textList, itertools.cycle(keyList)):
# processing

第 2 部分

如果要获取的索引大于letterList的长度,则要从前面重新开始。这意味着要获取的索引是索引的模数和列表的长度:

encryptedList.append(letterList[tempIndex % len(letterList)])

查找索引的最坏情况复杂度为 O(n),这意味着如果需要的元素位于末尾,它将查找列表中的每个元素。为了使这些查找更快,在开始之前构建键的字典并查找索引(O(1) 复杂度):

lettermap = {letter: i for i, letter in enumerate(letterList)}

然后在你的循环中:

if character in lettermap:
tempIndex = lettermap[character]

一起

def encrypt0r(text, keys, letters):
encrypted = []
lettermap = {letter: i for i, letter in enumerate(letters)}

for character, key in zip(text, itertools.cycle(keys)):
if character in lettermap:
new_index = lettermap[character] + key
encrypted.append(letters[new_index%len(letters)])
else:
encrypted.append(character)
return "".join(encrypted)

关于python - 如何多次循环访问相同的列表?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48733978/

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