繁体   English   中英

如何在Python中按字母降序获得下一个字符串?

[英]How can I get the next string, in alphabetical DESCENDING order, in Python?

我需要一个简单的python程序,该程序在列表中查找字符串,如果找不到,则会在字母降序中生成下一个字符串 。我的意思是,如果找不到``abz'' ,它将生成ac删除到达'z'时的最后一个字符。

另一个例子:

我有一个列表,例如:list = ['allena','allend','alphosis','alpinist','alternative']

假设我不知道列表中有什么。

该功能后发现allend在列表中,将检查丙二烯allenz,alleoallez后后全部allz ......从而通过字符串中移除最后一个字符每次它是“Z” ....功能会达到alpalt ...直到达到a

该函数将更改字符串的最后一个字符,并在其变为“ z”时将其删除,直到仅保留第一个字符为止。

感谢大伙们!

这是使用过滤器函数过滤您的问题的一种方法,该函数消耗了规范中生成的单词列表。

findall = lambda pred, word: filter(pred, words_gen(word)) 

def words_gen(word):
    yield word
    while True:
        lastchr = word[-1]
        if len(word) == 1 and lastchr == 'z':
            break

        new_lastchr = chr(97 + ((ord(lastchr) - 96) % 26))
        if lastchr == 'z':
            word = word[:-2] + new_lastchr
        else:
            word = word[:-1] + new_lastchr
        yield word


def check_match(it):
    def match(word):
        try:
            it.index(word)
        except ValueError:
            return False
        else:
            return True
    return match

lst = ['allena', 'allend','alphosis','alpinist', 'alternative']

> print(list(findall(check_match(lst), 'allena')))

['allena', 'allend']

使用生成器功能!

def mygenerator(word):
  while len(word) > 0:
    lastletter = word[-1].lower()    # get last letter
    word = word[0:-1]                # remove last letter
    for lv in range(ord(lastletter), ord('z')+1):
      letter = chr(lv)
      yield word+letter

这是一个测试:

>>> print(list(mygenerator('jason')))
['jason', 'jasoo', 'jasop', 'jasoq', 'jasor', 'jasos', 'jasot', 'jasou', 'jasov', 'jasow', 'jasox', 'jasoy', 'jasoz', 'jaso', 'jasp', 'jasq', 'jasr', 'jass', 'jast', 'jasu', 'jasv', 'jasw', 'jasx', 'jasy', 'jasz', 'jas', 'jat', 'jau', 'jav', 'jaw', 'jax', 'jay', 'jaz', 'ja', 'jb', 'jc', 'jd', 'je', 'jf', 'jg', 'jh', 'ji', 'jj', 'jk', 'jl', 'jm', 'jn', 'jo', 'jp', 'jq', 'jr', 'js', 'jt', 'ju', 'jv', 'jw', 'jx', 'jy', 'jz', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']

这实现了您请求的大多数逻辑。 我希望它有助于说明python多么灵活和强大。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM