Pythonのアルファベット範囲


423

次のようなアルファベット文字のリストを作成する代わりに:

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

それを範囲または何かにグループ化する方法はありますか?たとえば、数値の場合は次のようにグループ化できますrange()

range(1, 10)

いくつかの答えはpython 3のアップデートが必要なようです?
チャーリーパーカー

2
私が使用しているため@CharlieParkerありませんが、最初から私は、必ず私の答えは、同時にPythonの3だけでなく、Pythonの2に働くだろう作られたstring.ascii_lowercase(両方で利用可能)およびませんstring.lowercase(のみPY2上)
jamylak

デュープstackoverflow.com/questions/14927114/...(もだまされやすい人のようです自身)
hkBst

@hkBst違いは、これらの質問は文字のサブセット範囲を要求しているのに対し、これはアルファベット全体を要求する(これにより答えがより具体的になります)
jamylak

回答:


765
>>> 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 2013

63
string.ascii_lowercase[::-1]
jamylak 2013

map(...)の結果の明示的なlist(...)は、mapが既にリストを返しているので不必要です
haavee 2014年

1
@haavee実際には、Python 3 mapではnoが返されませんlist
jamylak

1
特定のロケールのための同じことを行う方法があるかしら、すなわち取得スペイン語、トルコ語などのアルファベット
ゴンサロ

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

1
[chr(alpha + 97)for alpha for 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_lettersstring.ascii_lowercasestring.ascii_uppercasePythonですべての作業3+。
SlimPDX 2017年

@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 2018年

3

letters[1:10]Rからの同等のものを探している場合は、次を使用できます。

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

1

組み込みの範囲関数を使用して、Pythonで大文字と小文字のアルファベットを出力します

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.