【问题标题】:Alphabet range in PythonPython中的字母范围
【发布时间】:2013-04-10 06:23:13
【问题描述】:

而不是像这样列出字母字符:

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

有什么方法可以将它分组到一个范围或什么的?例如,对于数字,可以使用 range() 进行分组:

range(1, 10)

【问题讨论】:

  • 似乎某些答案可能需要更新 python 3?
  • @CharlieParker 不,从一开始我就确保我的答案同时适用于 Python 3 和 Python 2,因为我使用了 string.ascii_lowercase(两者都可用)而不是 @987654326 @(仅在 py2 上)
  • stackoverflow.com/questions/14927114/… 的欺骗(它本身似乎也是一个欺骗)
  • @hkBst 似乎不同之处在于这些问题要求字母的子集范围,而这个要求整个字母表(这使得答案更具体)

标签: python string list alphabet


【解决方案1】:
>>> 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'

【讨论】:

  • 谢谢。我如何使它颠倒顺序?
  • string.ascii_lowercase[::-1]
  • @haavee 实际上在 Python 3 中没有 map 不会返回 list
  • 我想知道是否有办法为特定的语言环境做同样的事情,即获取西班牙语、土耳其语等字母
【解决方案2】:

在 Python 2.7 和 3 中,您可以使用:

import string
string.ascii_lowercase
'abcdefghijklmnopqrstuvwxyz'

string.ascii_uppercase
'ABCDEFGHIJKLMNOPQRSTUVWXYZ'

正如@Zaz 所说: string.lowercase 已弃用,不再适用于 Python 3,但 string.ascii_lowercase 两者都适用

【讨论】:

  • 在 Python 3 中,使用 string.ascii_lowercase。但这会返回一个字符串。如果你需要一份清单,我认为 Bg1850 是一个很好的解决方案
  • 正如最重要的答案所提到的,string.ascii_lettersstring.ascii_lowercasestring.ascii_uppercase 都在 python 3+ 中工作。
  • @peterb list(string.ascii_lowercase)
【解决方案3】:
[chr(i) for i in range(ord('a'),ord('z')+1)]

【讨论】:

  • 我得到:[chr(alpha+97) for alpha in range(0,27)] 但这更直观。不需要记住 a 的 ascii 是 97
  • @MoeChughtai 我不明白这怎么比string.ascii_lowercase更简洁@
  • 还有:chrange = lambda s: "".join(map(chr, range(*map(ord, s))) + [c[1]])。用法:&gt;&gt;&gt; chrange("az") -&gt; 'abcdefghijklmnopqrstuvwxyz'。对于列表,只需删除 "".join( )
  • @jamylak 也许 MoeChughtai 的意思是这个答案真的不会淹没在冗长的解释中的解决方案。
  • @Fornost import string 是一个冗长的解释?
【解决方案4】:

这是一个简单的字母范围实现:

代码

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']

【讨论】:

  • 非常好!也适用于非拉丁字符。我刚试过。
【解决方案5】:

如果您正在寻找 R 中的 letters[1:10] 等价物,您可以使用:

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

【讨论】:

    【解决方案6】:

    使用内置范围函数在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();
    

    【讨论】:

      【解决方案7】:

      这是我能想到的最简单的方法:

      #!/usr/bin/python3
      for i in range(97, 123):
          print("{:c}".format(i), end='')
      

      因此,97 到 122 是 ASCII 数字,相当于 'a' to 和 'z'。注意小写和需要输入 123,因为它不会被包括在内)。

      在打印功能中确保设置{:c}(字符)格式,在这种情况下,我们希望它一起打印,甚至不让新行结尾,所以end=''会这样做工作。

      结果是这样的: abcdefghijklmnopqrstuvwxyz

      【讨论】:

        【解决方案8】:

        以下是我如何实现基于string.ascii_letters 生成字母范围的自定义函数:

        from string import ascii_letters
        
        
        def range_alpha(start_letter, end_letter):
          return ascii_letters[
            ascii_letters.index(start_letter):ascii_letters.index(end_letter) + 1
          ]
        
        print(range_alpha('a', 'z'))
        print(range_alpha('A', 'Z'))
        print(range_alpha('a', 'Z'))
        

        【讨论】:

          猜你喜欢
          • 2012-05-30
          • 2012-07-18
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 2020-01-29
          • 2011-10-23
          相关资源
          最近更新 更多