175

islowerとについては知ってisupperいますが、その文字が文字かどうか確認できますか? 例えば:

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

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

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

またはを行う以外に、それがキャラクターであるかどうかを尋ねる方法はあります.islower().isupper()?

4

6 に答える 6

268

使用できますstr.isalpha()

例えば:

s = 'a123b'

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

出力:

a True
1 False
2 False
3 False
b True
于 2013-03-21T21:24:43.883 に答える
36
str.isalpha()

文字列内のすべての文字がアルファベットで、少なくとも 1 文字ある場合は true、そうでない場合は false を返します。アルファベット文字は、Unicode 文字データベースで「Letter」として定義されている文字です。つまり、一般的なカテゴリ プロパティが「Lm」、「Lt」、「Lu」、「Ll」、または「Lo」のいずれかである文字です。これは、Unicode 標準で定義されている「Alphabetic」プロパティとは異なることに注意してください。

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)
>>>
于 2016-10-19T03:00:24.910 に答える
2

関数と基本コードを使用してこれを行う良い方法を見つけました。これは、文字列を受け入れ、大文字、小文字、および「その他」の数をカウントするコードです。その他は、スペース、句読点、さらには日本語や漢字に分類されます。

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.")
于 2018-11-20T07:05:51.103 に答える
1

これは機能します:

any(c.isalpha() for c in 'string')
于 2020-03-30T11:07:56.157 に答える
-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.")
于 2017-04-15T08:00:03.937 に答える