Python中的字母范围

Python中的字母范围,python,string,list,alphabet,Python,String,List,Alphabet,不要像这样列出字母表字符: alpha = ['a', 'b', 'c', 'd'.........'z'] 我们有没有办法把它分成一个范围或什么的?例如,对于数字,可以使用range(): 如果您确实需要列表: >>> list(string.ascii_lowercase) ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't',

不要像这样列出字母表字符:

alpha = ['a', 'b', 'c', 'd'.........'z']
我们有没有办法把它分成一个范围或什么的?例如,对于数字,可以使用
range()

如果您确实需要列表:

>>> 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']
其他有用的
字符串
模块功能:

>>> 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'
Python 3上的帮助(字符串) .... 资料 ascii字母='abcdefghijklmnopqrstuvxyzabcdefghijklmnopqrstuvxyz' ascii_小写='abcdefghijklmnopqrstuvwxyz' ascii_大写='ABCDEFGHIJKLMNOPQRSTUVWXYZ' 数字='0123456789' hexdigits='0123456789ABCDEFABCDDEF' 八位数='01234567' 可打印='0123456789abcdefghijklmnopqrstuvxyzabcdefghijklmnopqrstuvxyz!“#$%&\'()*+,-./:;?@[\]^ `{124;}~\ t\n\r\x0b\x0c” 标点符号='!“#$%&\'()*+,-./:@[\\]^_`{|}~' 空白='\t\n\r\x0b\x0c'
在Python 2.7和3中,您可以使用:

import string
string.ascii_lowercase
'abcdefghijklmnopqrstuvwxyz'

string.ascii_uppercase
'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
正如@Zaz所说:
string.lowercase
已被弃用,不再适用于Python 3,但
string.ascii\u 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中的
字母[1:10]
,您可以使用:

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

使用内置的range函数在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的必要性,因为它将不包括在内)

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

结果是:
abcdefghijklmnopqrstuvwxyz

以下是我如何实现基于
字符串的字母范围生成自定义函数。ascii_字母

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

谢谢如何使其反向排列?
string.ascii_lowercase[::-1]
@haavee实际上在Python 3中不是
map
不会返回
列表
我想知道是否有办法对特定的区域设置执行相同的操作,即获取西班牙语、土耳其语等。alphabets@Gonzalo也许我得到了:[chr(alpha+97)表示alpha在(0,27)范围内]但这更直观。不需要记住a的ascii是97@MoeChughtai我不明白这怎么会比
string.ascii_小写
还要简洁:
chrange=lambda s::.join(map(chr,range(*map(ord,s)))+[c[1]])
。用法:
>>chrange(“az”)->“abcdefghijklmnopqrstuvwxyz”
。对于列表,只需删除
”。join()
@jamylak可能MoeChughtai的意思是,这个答案并没有让解决方案淹没在冗长的解释中。@Fornost
import string
是一个冗长的解释?在Python 3中,使用string.ascii\u小写。但这会返回一个字符串。如果你需要一个列表,我认为Bg1850是一个很好的解决方案,正如上面的答案所提到的,
string.ascii_字母
string.ascii_小写字母
string.ascii_大写字母
似乎有些答案可能需要更新python 3?@CharlieParker No,从一开始,我就确保我的答案同时适用于Python3和Python2,因为我使用了
string.ascii_lowercase
(两者都可用)而不是
string.lowercase
(仅适用于py2)dupe of(它本身似乎也是一个dupe)@hkBst似乎不同的是,这些问题要求的是字母的子集范围,而这一个要求整个字母表(这使答案更具体)非常好!也适用于非拉丁字符。我刚试过。
#!/usr/bin/python3
for i in range(97, 123):
    print("{:c}".format(i), end='')
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'))