题
我需要一个简单的程序,给定的字符串,返回到我的字母数字顺序下一个(或只是字母顺序)。
f("aaa")="aab"
f("aaZ")="aba"
和等。
是否有已经模块?
的一个这样的功能解决方案
我不认为有一个内置的功能来做到这一点。以下应该工作:
def next_string(s):
strip_zs = s.rstrip('z')
if strip_zs:
return strip_zs[:-1] + chr(ord(strip_zs[-1]) + 1) + 'a' * (len(s) - len(strip_zs))
else:
return 'a' * (len(s) + 1)
说明:你找到的最后一个字符是不是z
,增加它,并与a
的替换所有的字符之后。如果整个字符串是z
的,则返回所有a
的的一个字符串,它是一个长。
其他提示
在你会如何翻译这在Perl到Python?的是否足够?不是100%,你问什么,但接近...
一个不同,时间越长,但也许更易读和灵活的解决方案:
def toval(s):
"""Converts an 'azz' string into a number"""
v = 0
for c in s.lower():
v = v * 26 + ord(c) - ord('a')
return v
def tostr(v, minlen=0):
"""Converts a number into 'azz' string"""
s = ''
while v or len(s) < minlen:
s = chr(ord('a') + v % 26) + s
v /= 26
return s
def next(s, minlen=0):
return tostr(toval(s) + 1, minlen)
s = ""
for i in range(100):
s = next(s, 5)
print s
您的字符串转换成数,其中每个字母代表在基座26的一个数字,由一个增加的数目和转换的数目返回到字符串。这样,您就可以表示为字母串值做任意数学。
在 '' minlen '' 参数控制多少位数字的结果将具有(自0 ==一个== AAAAA)。
吮吸那蟒蛇没有什么Ruby有:String#next
因此,这里是一个低劣的解决方案来处理的字母数字字符串:
def next_string(s):
a1 = range(65, 91) # capital letters
a2 = range(97, 123) # letters
a3 = range(48, 58) # numbers
char = ord(s[-1])
for a in [a1, a2, a3]:
if char in a:
if char + 1 in a:
return s[:-1] + chr(char + 1)
else:
ns = next_string(s[:-1]) if s[:-1] else chr(a[0])
return ns + chr(a[0])
print next_string('abc') # abd
print next_string('123') # 124
print next_string('ABC') # ABD
# all together now
print next_string('a0') # a1
print next_string('1a') # 1b
print next_string('9A') # 9B
# with carry-over
print next_string('9') # 00
print next_string('z') # aa
print next_string('Z') # AA
# cascading carry-over
print next_string('a9') # b0
print next_string('0z') # 1a
print next_string('Z9') # AA0
print next_string('199') # 200
print next_string('azz') # baa
print next_string('Zz9') # AAa0
print next_string('$a') # $b
print next_string('$_') # None... fix it yourself
不是很大。还挺为我工作。
不隶属于 StackOverflow