Диапазон алфавита в Python


424

Вместо того, чтобы составлять список букв алфавита, как это:

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

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

range(1, 10)

Кажется, какой-то ответ может потребоваться обновление для Python 3?
Чарли Паркер

2
@CharlieParker Нет, с самого начала я убедился, что мой ответ будет работать и на Python 3, и на Python 2 одновременно, потому что я использовал string.ascii_lowercase(доступно на обоих), а не string.lowercase(только на py2)
jamylak

dupe of stackoverflow.com/questions/14927114/… (который сам по себе также выглядит как обман)
hkBst

@hkBst Кажется, разница в том, что эти вопросы задают подмножество букв, в то время как этот вопрос запрашивает весь алфавит (что делает ответ более конкретным)
jamylak

Ответы:


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

2
Спасибо. Как мне сделать это в обратном порядке?
Алекса Элис

64
string.ascii_lowercase[::-1]
jamylak

Явный список (...) результата map (...) является излишним, так как map уже возвращает список
haavee

1
@haavee На самом деле нет в Python 3 mapне возвращаетlist
jamylak

1
Интересно, есть ли способ сделать то же самое для конкретной локали, то есть получить испанский, турецкий и т. Д. Алфавиты
Гонсало

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

1
Я получил: [chr (альфа + 97) для альфа в диапазоне (0,27)], но это гораздо более интуитивно понятно. Не требует запоминания того, что ascii of a 97
peterb

5
@MoeChughtai Я не понимаю, как это более кратко, чемstring.ascii_lowercase
jamylak

Кроме того : chrange = lambda s: "".join(map(chr, range(*map(ord, s))) + [c[1]]). Использование: >>> chrange("az") -> 'abcdefghijklmnopqrstuvwxyz'. Для списка, просто удалите"".join( )
Брэден Бест

@jamylak Может быть, MoeChughtai подразумевал, что этот ответ действительно не затопляет решение в длинных объяснениях.
Форност

1
@Fornost import string- это длинное объяснение?
jamylak

34

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

import string
string.ascii_lowercase
'abcdefghijklmnopqrstuvwxyz'

string.ascii_uppercase
'ABCDEFGHIJKLMNOPQRSTUVWXYZ'

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


2
В Python 3 используйте string.ascii_lowercase. Но это возвращает строку. Если вам нужен список, я думаю, Bg1850 - это
отличное

В верхнем ответе упоминает string.ascii_letters, string.ascii_lowercase, string.ascii_uppercaseвсе работы в питоне 3+.
SlimPDX

@peterblist(string.ascii_lowercase)
Брэден Бест

11

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

Код

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

2
Очень хорошо! Также работает с нелатинскими символами. Я только что попробовал.
MarkS

3

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

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

1

Печатайте верхний и нижний регистры в Python, используя встроенную функцию range

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();

1

Это самый простой способ, который я могу понять:

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

Таким образом, от 97 до 122 являются числами ASCII, эквивалентными 'a' to и 'z'. Обратите внимание на строчные буквы и необходимость поставить 123, так как он не будет включен).

В функции печати убедитесь, что вы установили {:c}(символьный) формат, и, в этом случае, мы хотим, чтобы он печатал все это вместе, даже не пропуская новую строку в конце, так end=''что сделаем эту работу.

Результат таков: abcdefghijklmnopqrstuvwxyz

Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.