我想得到这样的序列
a,b,c,.......,x,y,z,aa,ab,ac,....,az,ba,bb,....,bz,.. ..,aaa,....,azz.....,zzz,...
依此类推,直到我达到给定的长度。
我的问题是我不知道如何编写无限数量的循环。
abc = 'abcdefghijklmnopqrstuvwxyz'
def next_plate(i):
for letter in abc:
i += 1
yield letter, i
num_plates = 10000
i = 0
all_plates = {}
for plate,i in next_plate(i):
if i > num_plates:
break
all_plates[i] = plate
if i < num_plates:
for plate_1, _ in next_plate(i):
for plate_2,i in next_plate(i):
if i > num_plates:
break
all_plates[i] = plate_1 + plate_2
if i < num_plates:
for plate_1, _ in next_plate(i):
for plate_2, _ in next_plate(i):
for plate_3,i in next_plate(i):
if i > num_plates:
break
all_plates[i] = plate_1 + plate_2 + plate_3
有人可以帮我吗?
这是一个基于 itertools 的生成器:
import itertools, string
def plates():
n = 1
while True:
for plate in itertools.product(string.ascii_lowercase,repeat = n):
yield ''.join(plate)
n += 1
#test:
p = plates()
test = [next(p) for _ in range(10000)]
print(test[:30])
print(test[-30:])
输出:
['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', 'aa', 'ab', 'ac', 'ad']
['nsm', 'nsn', 'nso', 'nsp', 'nsq', 'nsr', 'nss', 'nst', 'nsu', 'nsv', 'nsw', 'nsx', 'nsy', 'nsz', 'nta', 'ntb', 'ntc', 'ntd', 'nte', 'ntf', 'ntg', 'nth', 'nti', 'ntj', 'ntk', 'ntl', 'ntm', 'ntn', 'nto', 'ntp']
我是一名优秀的程序员,十分优秀!