568

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

alpha = ['a', 'b', 'c', 'd'.........'z']

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

range(1, 10)
4

8 回答 8

1042
>>> import string
>>> string.ascii_lowercase
'abcdefghijklmnopqrstuvwxyz'

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

>>> 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']

并做到这一点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']

其他有用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'
于 2013-04-17T13:07:13.743 回答
139
[chr(i) for i in range(ord('a'),ord('z')+1)]
于 2016-06-09T04:26:14.460 回答
50

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

import string
string.ascii_lowercase
'abcdefghijklmnopqrstuvwxyz'

string.ascii_uppercase
'ABCDEFGHIJKLMNOPQRSTUVWXYZ'

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

于 2015-08-08T00:02:03.657 回答
15

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

代码

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_)

演示

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

list(letter_range("a", "f", step=2))
# ['a', 'c', 'e']
于 2018-02-09T03:20:50.300 回答
9

如果您正在寻找来自 R 的等价物letters[1:10],您可以使用:

import string
list(string.ascii_lowercase[0:10])
于 2019-05-14T15:38:32.183 回答
6

这是我能想到的最简单的方法:

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

因此,97 到 122 是 ASCII 数字,相当于“a”到“z”。注意小写和需要输入 123,因为它不会被包括在内)。

在打印函数中确保设置{:c}(字符)格式,在这种情况下,我们希望它一起打印,甚至不让最后一行换行,这样end=''就可以了。

结果是这样的: abcdefghijklmnopqrstuvwxyz

于 2020-04-28T22:09:16.367 回答
4

使用内置范围函数在 python 中打印大写和小写字母

def upperCaseAlphabets():
    print("Upper Case Alphabets")
    for i in range(65, 91):
        print(chr(i), end=" ")
    print()

def lowerCaseAlphabets():
    print("Lower Case Alphabets")
    for i in range(97, 123):
        print(chr(i), end=" ")

upperCaseAlphabets();
lowerCaseAlphabets();
于 2020-03-11T07:42:35.710 回答
2

以下是我如何实现基于以下的字母范围生成的自定义函数string.ascii_letters

from string import ascii_letters


def range_alpha(start_letter, end_letter):
  return ascii_letters[
    ascii_letters.index(start_letter):ascii_letters.index(end_letter) + 1
  ]

print(range_alpha('a', 'z'))
print(range_alpha('A', 'Z'))
print(range_alpha('a', 'Z'))
于 2021-03-04T12:38:37.543 回答