字母范围python

Ale*_*lis 369 python string list alphabet

而不是像这样制作字母表列表:

alpha = ['a', 'b', 'c', 'd'.........'z']
Run Code Online (Sandbox Code Playgroud)

有什么方法可以将它分组到一个范围或什么的?例如,对于数字,可以使用它进行分组range()

range(1, 10)
Run Code Online (Sandbox Code Playgroud)

jam*_*lak 669

>>> import string
>>> string.ascii_lowercase
'abcdefghijklmnopqrstuvwxyz'
Run Code Online (Sandbox Code Playgroud)

如果你真的需要一个清单:

>>> list(string.ascii_lowercase)
['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']
Run Code Online (Sandbox Code Playgroud)

并做到这一点 range

>>> list(map(chr, range(97, 123))) #or list(map(chr, range(ord('a'), ord('z')+1)))
['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']
Run Code Online (Sandbox Code Playgroud)

其他有用的string模块功能:

>>> help(string) # on Python 3
....
DATA
    ascii_letters = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'
    ascii_lowercase = 'abcdefghijklmnopqrstuvwxyz'
    ascii_uppercase = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
    digits = '0123456789'
    hexdigits = '0123456789abcdefABCDEF'
    octdigits = '01234567'
    printable = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ!"#$%&\'()*+,-./:;<=>?@[\\]^_`{|}~ \t\n\r\x0b\x0c'
    punctuation = '!"#$%&\'()*+,-./:;<=>?@[\\]^_`{|}~'
    whitespace = ' \t\n\r\x0b\x0c'
Run Code Online (Sandbox Code Playgroud)

  • `string.ascii_lowercase [:: - 1]` (57认同)
  • 用`range`做一个更透明的方法:`list(map(chr,range(ord('a'),ord('z')+ 1)))`. (19认同)
  • 谢谢。我如何使它颠倒顺序? (2认同)
  • @haavee 实际上,Python 3 中的“map”不返回“list” (2认同)
  • 我想知道是否有一种方法可以针对特定区域设置执行相同的操作,即获取西班牙语、土耳其语等字母表 (2认同)
  • @eladsilver`string.lowercase`在Py3中不起作用 (2认同)

Bg1*_*850 93

[chr(i) for i in range(ord('a'),ord('z')+1)]
Run Code Online (Sandbox Code Playgroud)

  • @MoeChughtai我不明白这比`string.ascii_lowercase更简洁 (5认同)
  • 我得到:[chr(alpha+97) for alpha in range(0,27)] 但这更直观。不需要记住 a 的 ascii 是 97 (3认同)
  • @Fornost `导入字符串` 是一个冗长的解释吗? (2认同)

Tri*_*yen 28

在Python 2.7和3中,您可以使用:

import string
string.ascii_lowercase
'abcdefghijklmnopqrstuvwxyz'

string.ascii_uppercase
'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
Run Code Online (Sandbox Code Playgroud)

正如@Zaz所说: string.lowercase已弃用,不再适用于Python 3,但string.ascii_lowercase在两者中都有效

  • `string.lowercase`已弃用,不再适用于Python 3. (11认同)
  • 在Python 3中,使用string.ascii_lowercase.但这会返回一个字符串.如果你需要一个清单,我认为,Bg1850是一个很好的解决方案 (2认同)
  • @peterb `列表(string.ascii_lowercase)` (2认同)

pyl*_*ang 10

这是一个简单的字母范围实现:

def letter_range(start, stop="{", step=1):
    """Yield a range of lowercase letters.""" 
    for ord_ in range(ord(start.lower()), ord(stop.lower()), step):
        yield chr(ord_)
Run Code Online (Sandbox Code Playgroud)

演示

list(letter_range("a", "f"))
# ['a', 'b', 'c', 'd', 'e']

list(letter_range("a", "f", step=2))
# ['a', 'c', 'e']
Run Code Online (Sandbox Code Playgroud)

  • 非常好!也适用于非拉丁字符。我刚试过。 (2认同)

Qas*_*wed 7

如果您正在寻找等效letters[1:10]于 R 的内容,您可以使用:

import string
list(string.ascii_lowercase[0:10])
Run Code Online (Sandbox Code Playgroud)


Ric*_*pie 5

这是我能弄清楚的最简单的方法:

#!/usr/bin/python3
for i in range(97, 123):
    print("{:c}".format(i), end='')
Run Code Online (Sandbox Code Playgroud)

因此,97 到 122 是等效于 'a' to 和 'z' 的 ASCII 数字。注意小写和需要输入 123,因为它不会被包括在内)。

在打印功能中确保设置{:c}(字符)格式,在这种情况下,我们希望它一起打印它甚至不让末尾换行,这样end=''就可以完成这项工作。

结果是这样的: abcdefghijklmnopqrstuvwxyz