파이썬의 알파벳 범위


423

다음과 같이 알파벳 문자 목록을 만드는 대신 :

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

우리가 그것을 범위 또는 무언가로 그룹화 할 수있는 방법이 있습니까? 예를 들어 숫자의 경우 다음을 사용하여 그룹화 할 수 있습니다 range().

range(1, 10)

파이썬 3에 대한 일부 답변을 업데이트해야 할 수도 있습니까?
Charlie Parker

2
내가 사용하기 때문에 @CharlieParker 아니, 처음부터 나는 확실히 내 대답이 동시에 파이썬 3뿐만 아니라 파이썬이 작동 할 만든 string.ascii_lowercase(모두 가능)과하지 string.lowercase(만 py2에)
jamylak

stackoverflow.com/questions/14927114/의 속임수 (… 그 자체도 속임수처럼 보인다)
hkBst

@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
감사. 역순으로 바꾸려면 어떻게해야합니까?
Alexa Elis

63
string.ascii_lowercase[::-1]
jamylak

지도가 이미 목록 반환 이후지도의 결과에 대한 명시 적 목록 (...)는 (...) 불필요
haavee

1
@haavee 파이썬 3에서 실제로 no는 map반환하지 않습니다list
jamylak

1
스페인어, 터키어 등의 특정 로케일에 대해 동일한 작업을 수행 할 수있는 방법이 있는지 궁금합니다.
Gonzalo

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

1
나는 얻었다 : [chr (alpha + 97) in alpha in range (0,27)] 그러나 이것은 훨씬 더 직관적이다. a의 ascii가 97임을 기억할 필요는 없습니다.
peterb

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_lowercasestring.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

내장 범위 함수를 사용하여 파이썬에서 대문자 및 소문자 알파벳 인쇄

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는 'a'에서 'z'에 해당하는 ASCII 번호입니다. 소문자와 123을 넣을 필요가 있음을 주목하십시오.

인쇄 기능에서 {:c}(문자) 형식 을 설정했는지 확인하십시오 .이 경우 끝에 새 줄을 남기지 않고 함께 인쇄 end=''하여 작업을 수행하십시오.

결과는 다음과 같습니다. abcdefghijklmnopqrstuvwxyz

당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.