Как получить каждую возможную комбинацию фиксированной длины строки - PullRequest
0 голосов
/ 28 февраля 2020

У меня есть строка xxYxx, где x - буква az, а Y - число 0-9. Как я могу получить все возможные комбинации этого. Например:

aa1b ab2r xy9p

Есть все допустимые возможности.

Ответы [ 3 ]

1 голос
/ 28 февраля 2020

Использование itertools.product:

import itertools
from string import ascii_lowercase as alphabet

def all_strings():
    numbers = map(str, range(1, 11))
    return map(''.join, itertools.product(alphabet, alphabet, numbers, alphabet))

Пример:

>>> list(itertools.islice(all_strings(), 100))
['aa1a', 'aa1b', 'aa1c', 'aa1d', 'aa1e', 'aa1f', 'aa1g', 'aa1h', 'aa1i', 'aa1j',
 'aa1k', 'aa1l', 'aa1m', 'aa1n', 'aa1o', 'aa1p', 'aa1q', 'aa1r', 'aa1s', 'aa1t',
 'aa1u', 'aa1v', 'aa1w', 'aa1x', 'aa1y', 'aa1z', 'aa2a', 'aa2b', 'aa2c', 'aa2d',
 'aa2e', 'aa2f', 'aa2g', 'aa2h', 'aa2i', 'aa2j', 'aa2k', 'aa2l', 'aa2m', 'aa2n',
 'aa2o', 'aa2p', 'aa2q', 'aa2r', 'aa2s', 'aa2t', 'aa2u', 'aa2v', 'aa2w', 'aa2x',
 'aa2y', 'aa2z', 'aa3a', 'aa3b', 'aa3c', 'aa3d', 'aa3e', 'aa3f', 'aa3g', 'aa3h',
 'aa3i', 'aa3j', 'aa3k', 'aa3l', 'aa3m', 'aa3n', 'aa3o', 'aa3p', 'aa3q', 'aa3r',
 'aa3s', 'aa3t', 'aa3u', 'aa3v', 'aa3w', 'aa3x', 'aa3y', 'aa3z', 'aa4a', 'aa4b',
 'aa4c', 'aa4d', 'aa4e', 'aa4f', 'aa4g', 'aa4h', 'aa4i', 'aa4j', 'aa4k', 'aa4l',
 'aa4m', 'aa4n', 'aa4o', 'aa4p', 'aa4q', 'aa4r', 'aa4s', 'aa4t', 'aa4u', 'aa4v']
0 голосов
/ 28 февраля 2020

Это псевдокод, который должен дать представление о том, что вам нужно делать.

listOfStrings = [];
for x in [a ... z]
    for Y in [1 ... 10]
        string xYString = xxYxx;
        listOfStrings.append(xyString);
//listOfStrings now contains all desired combinations of xxYxx
0 голосов
/ 28 февраля 2020

Это какой-то Regex вам нужен? Или генератор для массива? В случае с Regex я бы сделал что-то вроде:

/^[a-z]{1,}([0-9]|10){1}[a-z]{1,}$/

Проверка в Regexr

В противном случае просто итерируйте все значения?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...