Faixa de alfabeto em Python

423

Em vez de fazer uma lista de caracteres do alfabeto como este:

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

existe alguma maneira de agrupá-lo em um intervalo ou algo assim? Por exemplo, para números, pode ser agrupado usando range():

range(1, 10)
Alexa Elis
fonte
parece que alguma resposta pode precisar de atualização para python 3?
Charlie Parker
2
@CharlieParker Não, desde o início, tenho a certeza que a minha resposta iria trabalhar em Python 3, bem como Python 2, ao mesmo tempo, porque eu usei string.ascii_lowercase(disponível em ambos) e não string.lowercase(apenas em PY2)
jamylak
dupe de stackoverflow.com/questions/14927114/... (que em si também parece ser um joguete)
hkBst
@hkBst Parece que a diferença é que essas perguntas estão pedindo uma gama subconjunto de cartas, enquanto este solicita o alfabeto inteiro (o que torna a resposta mais específica)
jamylak

Respostas:

765
>>> import string
>>> string.ascii_lowercase
'abcdefghijklmnopqrstuvwxyz'

Se você realmente precisa de uma lista:

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

E para fazer isso com 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']

Outros stringrecursos úteis do módulo:

>>> 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'
jamylak
fonte
2
Obrigado. Como faço para reverter a ordem?
Alexa Elis
63
string.ascii_lowercase[::-1]
jamylak
A lista explícita (...) sobre o resultado do mapa (...) é supérfluo desde mapa já retorna uma lista
haavee
1
@haavee Na verdade não em Python 3 mapnão retorna umlist
jamylak
1
Gostaria de saber se há uma maneira de fazer o mesmo para um local específico, ou seja, obter o espanhol, turco, etc. alfabetos
Gonzalo
106
[chr(i) for i in range(ord('a'),ord('z')+1)]
Bg1850
fonte
1
Eu obtive: [chr (alfa + 97) para alfa no intervalo (0,27)], mas isso é muito mais intuitivo. Não requer lembrando que ascii de um é de 97
peterb
5
@MoeChughtai Eu não entendo como isso é mais sucinto do questring.ascii_lowercase
jamylak
Também: chrange = lambda s: "".join(map(chr, range(*map(ord, s))) + [c[1]]). Uso: >>> chrange("az") -> 'abcdefghijklmnopqrstuvwxyz'. Para obter uma lista, basta remover"".join( )
Braden Best
@jamylak Talvez MoeChughtai tenha significado que essa resposta realmente não afoga a solução em longas explicações.
Fornost
1
@ Fornost import stringé uma explicação longa?
jamylak
34

No Python 2.7 e 3, você pode usar isso:

import string
string.ascii_lowercase
'abcdefghijklmnopqrstuvwxyz'

string.ascii_uppercase
'ABCDEFGHIJKLMNOPQRSTUVWXYZ'

Como o @Zaz diz: string.lowercaseestá obsoleto e não funciona mais no Python 3, mas string.ascii_lowercasefunciona nos dois

Trinh Nguyen
fonte
2
No Python 3, use string.ascii_lowercase. Mas isso retorna uma string. No caso de você precisa de uma lista, eu acho, Bg1850 é uma solução elegante
peterb
Como a resposta superior menciona, string.ascii_letters, string.ascii_lowercase, string.ascii_uppercasetodo o trabalho em python 3+.
precisa saber é o seguinte
@peterblist(string.ascii_lowercase)
Braden Best
11

Aqui está uma implementação simples de intervalo de letras:

Código

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

Demo

list(letter_range("a", "f"))
# ['a', 'b', 'c', 'd', 'e']

list(letter_range("a", "f", step=2))
# ['a', 'c', 'e']
pylang
fonte
2
Muito agradável! Também funciona com caracteres não latinos. Eu apenas tentei.
MarkS
3

Se você procura um equivalente a letters[1:10]partir de R, pode usar:

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

Imprima os alfabetos Maiúsculas e Minúsculas em python usando uma função de intervalo integrada

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();
lakshmikandan
fonte
1

Esta é a maneira mais fácil de descobrir:

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

Portanto, 97 a 122 são o número ASCII equivalente a 'a' a e 'z'. Observe as letras minúsculas e a necessidade de colocar 123, pois elas não serão incluídas).

Na função de impressão, defina o {:c}formato (caractere) e, nesse caso, queremos que ele imprima tudo juntos, sem deixar uma nova linha no final, assim end=''como o trabalho.

O resultado é este: abcdefghijklmnopqrstuvwxyz

RicarHincapie
fonte