Діапазон алфавіту в Python


423

Замість того, щоб складати список таких символів:

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 Здається, різниця полягає в тому, що ці запитання задають підмножину літер, тоді як цей запитує весь алфавіт (що робить відповідь більш конкретною)
jamylak

Відповіді:


764
>>> 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
Дякую. Як зробити так, щоб це було зворотним порядком?
Алекса Еліс

63
string.ascii_lowercase[::-1]
jamylak

Явний список (...) результату карти (...) є зайвим, оскільки карта вже повертає список
haavee

1
@haavee Насправді ні в Python 3 mapне повертається аlist
jamylak

1
Цікаво, чи є спосіб зробити те ж саме для конкретної мови, тобто отримати іспанські, турецькі тощо. Алфавітів
Gonzalo

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

1
Я отримав: [chr (альфа + 97) для альфа в діапазоні (0,27)], але це набагато інтуїтивніше. Не потрібно пам’ятати, що ascii a - 97
вівторок

5
@MoeChughtai Я не розумію, як це більш лаконічно, ніжstring.ascii_lowercase
jamylak

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

@jamylak Можливо, MoeChughtai означав, що ця відповідь насправді не заглушує рішення у тривалих поясненнях.
Fornost

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 - це акуратне рішення
peterb

У верхньому відповіді згадує string.ascii_letters, string.ascii_lowercase, string.ascii_uppercaseвсі роботи в Пітоні 3+.
SlimPDX

@peterblist(string.ascii_lowercase)
Braden Best

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 за допомогою вбудованої функції діапазону

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.