Как я могу пройти через неизвестное количество сегментов в Python? - PullRequest
2 голосов
/ 26 октября 2019

Я хочу получить последовательность вроде этой

a, b, c, ....., x, y, z, aa, ab, ac, ...., az, ба, бб, ...., бз, ...., ааа, ...., ацз ...., ззз, ...

и так далее, пока ядостичь заданной длины.

Моя проблема в том, что я не знаю, как закодировать бесконечное число циклов.

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

Может ли кто-нибудь помочь мне с этим?

Ответы [ 2 ]

2 голосов
/ 26 октября 2019

Вот генератор на основе 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']
0 голосов
/ 26 октября 2019

Вам необходимо использовать цикл while и установить для него значение true (добавление условия, которое нарушается при выполнении вашего условия). У меня сейчас нет компьютера, поэтому ответ очень краткий.

...