ช่วงตัวอักษรใน Python


423

แทนที่จะสร้างรายชื่อตัวอักษรแบบนี้:

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

มีวิธีใดบ้างที่เราสามารถจัดกลุ่มเป็นช่วงหรือบางสิ่ง? ตัวอย่างเช่นสำหรับตัวเลขสามารถจัดกลุ่มได้โดยใช้range():

range(1, 10)

ดูเหมือนคำตอบบางอย่างอาจต้องมีการอัพเดตสำหรับ python 3
Charlie Parker

2
@ CharlieParker ไม่ตั้งแต่ต้นฉันแน่ใจว่าคำตอบของฉันจะใช้กับ Python 3 และ Python 2 ในเวลาเดียวกันเพราะฉันใช้string.ascii_lowercase(มีให้ทั้งคู่) และไม่ใช่string.lowercase(เฉพาะกับ py2)
jamylak

dupe ของstackoverflow.com/questions/14927114/ … (ซึ่งตัวมันเองก็ดูเหมือนจะเป็น dupe)
hkBst

@hkBst ดูเหมือนความแตกต่างคือคำถามเหล่านั้นจะขอช่วงของชุดตัวอักษรในขณะที่คนนี้ขอตัวอักษรทั้งหมด (ซึ่งทำให้คำตอบที่เฉพาะเจาะจงมากขึ้น)
279242

คำตอบ:


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

รายการที่ชัดเจน (... ) จากผลลัพธ์ของแผนที่ (... ) นั้นไม่จำเป็นเนื่องจากแผนที่ส่งคืนรายการแล้ว
2557

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 ของ 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( )
Braden Best

@jamylak บางที MoeChughtai แปลว่าคำตอบนี้ไม่ได้ทำให้คำอธิบายยาวเกินไป
Fornost

1
@ ฟอสต์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 สุดยอด

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
ดีมาก! ใช้ได้กับอักขระที่ไม่ใช่ละติน ฉันแค่พยายาม
เครื่องหมาย

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 คือหมายเลข ASCII ที่เทียบเท่ากับ 'a' ถึงและ 'z' สังเกตเห็นตัวพิมพ์เล็กและความจำเป็นที่จะต้องใส่ 123 เพราะมันจะไม่รวม)

ในฟังก์ชั่นการพิมพ์ตรวจสอบให้แน่ใจว่าตั้งค่า{:c}รูปแบบ (ตัวอักษร) และในกรณีนี้เราต้องการให้พิมพ์ทั้งหมดเข้าด้วยกันโดยไม่ปล่อยให้ขึ้นบรรทัดใหม่ในตอนท้ายดังนั้นend=''จะต้องทำงาน

ผลลัพธ์คือ: abcdefghijklmnopqrstuvwxyz

โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.