Алфавитный ряд на Python

Вместо того, чтобы делать список алфавитов следующим образом:

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

Есть ли способ, чтобы мы могли группировать его в диапазон или что-то еще? Например, для чисел его можно сгруппировать с помощью range()

range(1, 10)

Ответ 1

>>> 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!"#$%&\'()*+,-./:;<=>[email protected][\\]^_`{|}~ \t\n\r\x0b\x0c'
    punctuation = '!"#$%&\'()*+,-./:;<=>[email protected][\\]^_`{|}~'
    whitespace = ' \t\n\r\x0b\x0c'

Ответ 2

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

Ответ 3

В Python 2.7 и 3 вы можете использовать это:

import string
string.ascii_lowercase
'abcdefghijklmnopqrstuvwxyz'

string.ascii_uppercase
'ABCDEFGHIJKLMNOPQRSTUVWXYZ'

Как говорит @Zaz: string.lowercase устарела и больше не работает в Python 3, но string.ascii_lowercase работает в обоих

Ответ 4

Вот простая реализация диапазона букв:

Код

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

Ответ 5

Если вы ищете эквивалент letters[1:10] от R, вы можете использовать:

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