重新排列 36 位数字



我是Python的业余爱好者,我制作了一个程序,它将编码一长串字符并输出6个字符。

def token (n):
    if n < 10:
        return chr( ord( '0' ) + (n) )
    if n in range (10, 36):
        return chr( ord( 'A' ) - 10 + (n))
    if n in range (37, 62):
        return chr( ord( 'a' ) - 36 + (n))
    if n is 62:
        return '-'
    if n is 63:
        return '+'

令牌将数字 (n) 转换为字符。大写和小写字母,包括字符"-"和"+"。

def encode (n):
    a = n // 1 % 64
    b = n // 64 % 64
    c = n // 64 ** 2 % 64
    d = n // 64 ** 3 % 64
    e = n // 64 ** 4 % 64
    f = n // 64 ** 5 % 64
    return (token(a) + token(b) + token(c) + token(d) + token(e) + token(f))

这是编码的其余部分。

print(encode(1234567890))
'IBWb91'

同样,有没有办法为输出的六个字符创建顺序?

这就是我目前所拥有的。我从一个现有的问题中得到了这个。

如何在 python 中对列表重新排序?

mylist = ['a','b','c','d','e','f',]
myorder = [6,5,4,3,2,1]
mylist = [ mylist[i] for i in myorder]

但。。。它给了我这个:

IndexError: list index out of range

我想发生什么:

>>> print(mylist)
['f','e','d','c','b','a'] 

我对此完全陌生。请帮忙:)

如果你只想反转列表,只需调用reverse方法或reversed函数:

>>> mylist = ['a','b','c','d','e','f']
>>> list(reversed(mylist))
['f', 'e', 'd', 'c', 'b', 'a']

如果你想以困难的方式做到这一点,你可以,但你必须使用实际在列表中的索引:

>>> [i for i, e in enumerate(mylist)]
[0, 1, 2, 3, 4, 5]

这些是列表中的索引。6 不是其中之一。因此,如果您尝试使用mylist[6],您将获得IndexError。你可能想要的是[5, 4, 3, 2, 1, 0].

python 中的列表是从 0 开始索引的,而不是从 1 开始索引的。如果要使用显示的方法对n元素列表进行重新排序,则需要一个包含数字的列表 0,1,...,n - 1 ,因为尝试访问n元素列表的元素n将给出错误,因为索引将超出预期范围。

例如,用你给的东西,

mylist = ['a','b','c','d','e','f']
myorder = [5,4,3,2,1,0]
mylist = [mylist[i] for i in myorder]

顺序必须为零索引。这就是 python 列表的工作方式 - 第一个元素是mylist[0],第二个元素是mylist[1],等等。因此,它应该是[5,4,3,2,1,0].

最新更新