[英]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,并alleo到allez后后全部以allz ......从而通过字符串中移除最后一个字符每次它是“Z” ....功能会达到alp和alt ...直到达到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.