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

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

当前回答

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

其他回答

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

如果你正在寻找R中[1:10]的等价字母,你可以使用:

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

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

import string
string.ascii_lowercase
'abcdefghijklmnopqrstuvwxyz'

string.ascii_uppercase
'ABCDEFGHIJKLMNOPQRSTUVWXYZ'

正如@Zaz所说: 字符串。小写字母已弃用,在python3中不再适用,只适用于字符串。Ascii_lowercase在这两种情况下都适用

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

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

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

在print函数中,确保设置了{:c}(字符)格式,并且,在这种情况下,我们希望它将所有内容一起打印,甚至不允许在末尾添加新行,因此end= "将完成这项工作。

结果是: abcdefghijklmnopqrstuvwxyz

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