Python中的字母范围

我如何创建一个字母字符列表,而不这样手动做?

['a', 'b', 'c', 'd', ..., 'z']
961217 次浏览
>>> 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)))
['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']

或者说:

>>> 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)
....
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'

在Python 2.7和3中,你可以使用这个:

import string
string.ascii_lowercase
'abcdefghijklmnopqrstuvwxyz'


string.ascii_uppercase
'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
正如@Zaz所说: string.lowercase已弃用,不再适用于python3,但string.ascii_lowercase适用于

[chr(i) for i in range(ord('a'),ord('z')+1)]

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

代码

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

如果你想从R中得到letters[1:10]的等价值,你可以使用:

import string
list(string.ascii_lowercase[0:10])

使用内置的范围函数打印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();

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

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

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

在打印函数中,确保设置{:c}(字符)格式,并且,在这种情况下,我们希望它打印在一起,甚至不让一个新的行结束,所以# eyz1将完成这项工作。

结果是这样的: # EYZ0 < / p >

以下是我如何基于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'))