ฉันจะตรวจสอบได้อย่างไรว่าอักขระในสตริงเป็นตัวอักษร? (งูใหญ่)


122

ฉันรู้เกี่ยวกับislowerและisupperแต่คุณสามารถตรวจสอบได้หรือไม่ว่าอักขระนั้นเป็นตัวอักษรหรือไม่? ตัวอย่างเช่น:

>>> s = 'abcdefg'
>>> s2 = '123abcd'
>>> s3 = 'abcDEFG'
>>> s[0].islower()
True

>>> s2[0].islower()
False

>>> s3[0].islower()
True

มีวิธีไหนแค่ถามว่าเป็นตัวละครนอกจากทำ.islower()หรือ.isupper()?


2
โปรดทราบว่า "อักขระคำ" ในการเขียนโปรแกรมมักจะหมายถึงตัวอักษรตัวเลขและขีดล่าง คำถามนี้ถามจริงเกี่ยวกับ "ตัวอักษร"; character.isalnum() or character == "_"ถ้าคุณจำเป็นต้องดูว่าตัวละครที่เป็นตัวอักษรคำว่าวิธีที่ดีที่สุดที่ฉันได้พบเป็น
Variadicism

ฉันรู้ แต่ฉันถามแบบนี้เมื่อ 3 ปีก่อนตอนที่ฉันเริ่มเขียนโปรแกรมครั้งแรก อย่าลังเลที่จะแก้ไข
O.rka

พอใช้. เราทุกคนเคยไปที่นั่น ฉันจะขอแก้ไข
Variadicism

คำตอบ:


191

คุณสามารถใช้str.isalpha().

ตัวอย่างเช่น:

s = 'a123b'

for char in s:
    print(char, char.isalpha())

เอาท์พุท:

a True
1 False
2 False
3 False
b True

9
โปรดทราบว่ามันใช้งานได้ดีกับตัวอักษรต่างๆเช่นกัน: >>> print [x.isalpha() for x in u'Español-한국어']ให้ [True, True, True, True, True, True, False, True, True, True] ตามที่คาดไว้
pryma

27
str.isalpha()

คืนค่าจริงหากอักขระทั้งหมดในสตริงเป็นตัวอักษรและมีอักขระอย่างน้อยหนึ่งตัวมิฉะนั้นจะเป็นเท็จ อักขระตามตัวอักษรคืออักขระที่กำหนดไว้ในฐานข้อมูลอักขระ Unicode เป็น "Letter" กล่าวคืออักขระที่มีคุณสมบัติหมวดหมู่ทั่วไปเป็นหนึ่งใน "Lm", "Lt", "Lu", "Ll" หรือ "Lo" โปรดทราบว่าคุณสมบัตินี้แตกต่างจากคุณสมบัติ“ Alphabetic” ที่กำหนดไว้ใน Unicode Standard

ใน python2.x:

>>> s = u'a1中文'
>>> for char in s: print char, char.isalpha()
...
a True
1 False
 True
 True
>>> s = 'a1中文'
>>> for char in s: print char, char.isalpha()
...
a True
1 False
 False
 False
 False
 False
 False
 False
>>>

ใน python3.x:

>>> s = 'a1中文'
>>> for char in s: print(char, char.isalpha())
...
a True
1 False
 True
 True
>>>

รหัสนี้ใช้ได้:

>>> def is_alpha(word):
...     try:
...         return word.encode('ascii').isalpha()
...     except:
...         return False
...
>>> is_alpha('中国')
False
>>> is_alpha(u'中国')
False
>>>

>>> a = 'a'
>>> b = 'a'
>>> ord(a), ord(b)
(65345, 97)
>>> a.isalpha(), b.isalpha()
(True, True)
>>> is_alpha(a), is_alpha(b)
(False, True)
>>>

4

ฉันพบวิธีที่ดีในการใช้ฟังก์ชันและโค้ดพื้นฐาน นี่คือรหัสที่ยอมรับสตริงและนับจำนวนตัวพิมพ์ใหญ่ตัวพิมพ์เล็กและ 'อื่น ๆ ' อื่น ๆ จัดเป็นช่องว่างเครื่องหมายวรรคตอนหรือแม้แต่ตัวอักษรญี่ปุ่นและจีน

def check(count):

    lowercase = 0
    uppercase = 0
    other = 0

    low = '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'
    upper = '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'



    for n in count:
        if n in low:
            lowercase += 1
        elif n in upper:
            uppercase += 1
        else:
            other += 1

    print("There are " + str(lowercase) + " lowercase letters.")
    print("There are " + str(uppercase) + " uppercase letters.")
    print("There are " + str(other) + " other elements to this sentence.")

str.isalphaง่ายกว่ามาก '
Aryan Beezadhur

1

data = "abcdefg hi j 12345"

digits_count = 0
letters_count = 0
others_count = 0

for i in userinput:

    if i.isdigit():
        digits_count += 1 
    elif i.isalpha():
        letters_count += 1
    else:
        others_count += 1

print("Result:")        
print("Letters=", letters_count)
print("Digits=", digits_count)

เอาท์พุท:

Please Enter Letters with Numbers:
abcdefg hi j 12345
Result:
Letters = 10
Digits = 5

โดยใช้str.isalpha()คุณสามารถตรวจสอบว่าเป็นตัวอักษรหรือไม่



-2

ใช้งานได้:

word = str(input("Enter string:"))
notChar = 0
isChar = 0
for char in word:
    if not char.isalpha():
        notChar += 1
    else:
        isChar += 1
print(isChar, " were letters; ", notChar, " were not letters.")

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