Python разбить строку в движущемся окне - PullRequest
11 голосов
/ 03 октября 2011

У меня есть строка с цифрами, вот так - digit = "7316717"

Теперь я хочу разбить строку таким образом, чтобы вывод представлял собой движущееся окно из 3 цифр одновременно.Итак, я получаю -

["731", "316", "167", "671", "717"]

Каким будет подход?Прямой способ - вставить цикл for и повторять.Но я чувствую, что некоторые встроенные функции Python могут сделать это в меньшем количестве кода.Знаешь какой-нибудь такой подход?

Ответы [ 4 ]

12 голосов
/ 03 октября 2011

Примеры itertools предоставляет функцию window, которая делает именно это:

from itertools import islice
def window(seq, n=2):
    "Returns a sliding window (of width n) over data from the iterable"
    "   s -> (s0,s1,...s[n-1]), (s1,s2,...,sn), ...                   "
    it = iter(seq)
    result = tuple(islice(it, n))
    if len(result) == n:
        yield result    
    for elem in it:
        result = result[1:] + (elem,)
        yield result

Пример использования:

>>> ["".join(x) for x in window("7316717", 3)]
['731', '316', '167', '671', '717']
8 голосов
/ 03 октября 2011
>>> s = "7316717"
>>> [s[i:i+3] for i in range(len(s)-2)]
['731', '316', '167', '671', '717']
3 голосов
/ 03 октября 2011

Существует очень хороший рецепт pairwise в документах itertools .

Немного модернизируя это для n элементов в группе, я сделал этот код:

from itertools import tee, izip

def window(iterable, n):
    els = tee(iterable, n)
    for i, el in enumerate(els):
        for _ in xrange(i):
            next(el, None)
    return izip(*els)


print(["".join(i) for i in window("2316515618", 3)])

Python 2.7

0 голосов
/ 03 октября 2011
digit = "7316717"
digit_sets = [digit[i:i+3] for i in range(len(digit)-2)]
...