Питон | Как сгруппировать значение в разные списки из основного списка с учетом определенного диапазона чисел для каждого индекса

OGlist = [A, B, C, D, E, 1, 2, 3, 4, 5, F, G, H, I, J, 6, 7, 8, 9, 10]
_list = []
_list2 = []

Итак, у меня есть список OGlist... Я хочу, чтобы первые 5 элементов OGlist были в _list , вторые 5 элементов OGlist в _list2, третьи 5 элементов в _list, четвертые 5 элементов в _list2 и т.д.

Как мне этого добиться?

Я пробовал это:

for x in range(1, len(OGlist) + 1):
    _list.append(OGlist[x-1])
    if x%5 == 0:
        y = x
        while True:
            _list2.append(OGlist[x])
            x += 1
            if x == y + 5:
                break

Какое условие и логику я должен использовать, чтобы получить желаемый результат?

Желаемый результат:

_list = [A, B, C, D, E, F, G, H, I, J]
_list2 = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
Почему в Python есть оператор "pass"?
Почему в Python есть оператор "pass"?
Оператор pass в Python - это простая концепция, которую могут быстро освоить даже новички без опыта программирования.
Некоторые методы, о которых вы не знали, что они существуют в Python
Некоторые методы, о которых вы не знали, что они существуют в Python
Python - самый известный и самый простой в изучении язык в наши дни. Имея широкий спектр применения в области машинного обучения, Data Science,...
Основы Python Часть I
Основы Python Часть I
Вы когда-нибудь задумывались, почему в программах на Python вы видите приведенный ниже код?
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
Алиса и Боб имеют неориентированный граф из n узлов и трех типов ребер:
Оптимизация кода с помощью тернарного оператора Python
Оптимизация кода с помощью тернарного оператора Python
И последнее, что мы хотели бы показать вам, прежде чем двигаться дальше, это
Советы по эффективной веб-разработке с помощью Python
Советы по эффективной веб-разработке с помощью Python
Как веб-разработчик, Python может стать мощным инструментом для создания эффективных и масштабируемых веб-приложений.
4
0
131
5
Перейти к ответу Данный вопрос помечен как решенный

Ответы 5

Если вы ищете один лайнер, это должно сделать это.

OGlist = [x, y, foo, bar, etc]

list_of_lists = [OGlist[i:i+5] for i in range(len(OGlist)-5) if i%5==0]

##GETTING LISTS AT EVEN INDEXES
_list = [l_ for i,l_ in enumerate(list_of_lists) if i%2 == 0]

##GETTING LISTS AT ODD INDEXES
_list2 = [l_ for i,l_ in enumerate(list_of_lists) if i%2 == 1]

##FLATTENING
from itertools import chain

_list = list(chain.from_iterable(_list))
_list2 = list(chain.from_iterable(_list2))

Он перебирает каждые 5 элементов (используя OGlist[i:i+5]) в списке (принудительно i%5==0), пока не достигнет точки, где элементов меньше 5 (применяется len(OGlist) - 5).

Тестирование:

╰─$ python                                                                                                                                                                  25ms
Python 3.8.3 (default, Jul  2 2020, 11:26:31)
[Clang 10.0.0 ] :: Anaconda, Inc. on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>> OGlist = list(range(100))
>>> OGlist
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99]
>>> list_of_lists = [OGlist[i:i+5] for i in range(len(OGlist)-5) if i%5==0]
>>> list_of_lists
[[0, 1, 2, 3, 4], [5, 6, 7, 8, 9], [10, 11, 12, 13, 14], [15, 16, 17, 18, 19], [20, 21, 22, 23, 24], [25, 26, 27, 28, 29], [30, 31, 32, 33, 34], [35, 36, 37, 38, 39], [40, 41, 42, 43, 44], [45, 46, 47, 48, 49], [50, 51, 52, 53, 54], [55, 56, 57, 58, 59], [60, 61, 62, 63, 64], [65, 66, 67, 68, 69], [70, 71, 72, 73, 74], [75, 76, 77, 78, 79], [80, 81, 82, 83, 84], [85, 86, 87, 88, 89], [90, 91, 92, 93, 94]]
>>> _list = [val for val in [l_ for i,l_ in enumerate(list_of_lists) if i%2 == 0]]
>>> _list2 = [val for val in [l_ for i,l_ in enumerate(list_of_lists) if i%2 == 1]]
>>> _list
[[0, 1, 2, 3, 4], [10, 11, 12, 13, 14], [20, 21, 22, 23, 24], [30, 31, 32, 33, 34], [40, 41, 42, 43, 44], [50, 51, 52, 53, 54], [60, 61, 62, 63, 64], [70, 71, 72, 73, 74], [80, 81, 82, 83, 84], [90, 91, 92, 93, 94]]
>>> _list2
[[5, 6, 7, 8, 9], [15, 16, 17, 18, 19], [25, 26, 27, 28, 29], [35, 36, 37, 38, 39], [45, 46, 47, 48, 49], [55, 56, 57, 58, 59], [65, 66, 67, 68, 69], [75, 76, 77, 78, 79], [85, 86, 87, 88, 89]]
>>> from itertools import chain
>>> _list = list(chain.from_iterable(_list))
>>> _list2 = list(chain.from_iterable(_list2))
>>> _list
[0, 1, 2, 3, 4, 10, 11, 12, 13, 14, 20, 21, 22, 23, 24, 30, 31, 32, 33, 34, 40, 41, 42, 43, 44, 50, 51, 52, 53, 54, 60, 61, 62, 63, 64, 70, 71, 72, 73, 74, 80, 81, 82, 83, 84, 90, 91, 92, 93, 94]
>>> _list2
[5, 6, 7, 8, 9, 15, 16, 17, 18, 19, 25, 26, 27, 28, 29, 35, 36, 37, 38, 39, 45, 46, 47, 48, 49, 55, 56, 57, 58, 59, 65, 66, 67, 68, 69, 75, 76, 77, 78, 79, 85, 86, 87, 88, 89]
>>>
Ответ принят как подходящий

Я бы подошел к этому так:

from itertools import chain

_list = list(chain.from_iterable(OGlist[i:i+5] for i in range(0, len(OGlist), 10)))
_list2 = list(chain.from_iterable(OGlist[i:i+5] for i in range(5, len(OGlist), 10)))

OGlist[i:i+5] for i in range(0, len(OGlist), 10) возвращает последовательность, подобную [[0, 1, 2, 3, 4], [10, 11, 12, 13, 14], ...], chain.from_iterable объединяет этот список списков в один список.

вот мой код

import numpy as np

size_array = 500 # example
big_list = [x for x in range(size_array)]
half_list1 = []
half_list2 = []


idx = [x for x in range(0,int(size_array/5), 2)]
idx = np.repeat(idx, 5)*5 + np.tile([1, 2, 3, 4, 5], int(size_array/10))

half_list1 = [big_list[i] for i in idx]
half_list2 = [big_list[i+5] for i in idx]
import functools
import operator

OGlist = [A, B, C, D, E, 1, 2, 3, 4, 5, F, G, H, I, J, 6, 7, 8, 9, 10]

groups = list(zip(*(iter(OGlist),)*5))
list_ =  functools.reduce(operator.iconcat, groups[1::2], [])
list_2 = functools.reduce(operator.iconcat, groups[::2], [])

Я хотел бы добавить более динамическое решение этой проблемы!

Если вы не знаете размер, если ваш список/массив, например, мы добавляем некоторые элементы (и также не кратны 5:

OGlist = ['A', 'B', 'C', 'D', 'E', 1, 2, 3, 4, 5, 'F', 'G', 'H', 'I', 'J', 6, 7, 8, 9, 10, 'AB', 'BB', 'CC', 'DD']

Посмотрите, что происходит:

groups = list(zip(*(iter(OGlist),)*5))
list_ =  functools.reduce(operator.iconcat, groups[1::2], [])
list_2 = functools.reduce(operator.iconcat, groups[::2], [])
print(list_, list_2)

ВЫХОД

# [1, 2, 3, 4, 5, 6, 7, 8, 9, 10] ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J']

Все остальные элементы исчезли!

ПРОСТОЕ РЕШЕНИЕ

ЗАМЕТЬТЕ, ЧТО МОЕ БУДЕТ УЛУЧШЕНО, ЭТО ПРОСТО КАК ПРИМЕР

from itertools import count


OGlist = ['A', 'B', 'C', 'D', 'E', 1, 2, 3, 4, 5, 'F', 'G', 'H', 'I', 'J', 6, 7, 8, 9, 10, 'AB', 'BB', 'CC', 'DD']


def get_partition(lst, start, stop):
    return lst[start:stop]

def alternator(lst):
    counting = count(0, 5)  # MAKES AN ITERATOR
    next(counting)
    limit = len(lst)
    _list = []
    _list2 = []
    prev = 0
    while limit >= 0:
        slicer_first = next(counting)  # GET First 5 Elements
        slicer_second = next(counting) # GET Second 5 Elements

        # ===== < GET ELEMENTS > ===== #
        first_block = get_partition(lst, prev, slicer_first)
        second_block = get_partition(lst, slicer_first, slicer_second)

        # ===== < ADD ELEMENTS TO LISTS > ===== #
        _list += first_block
        _list2 += second_block
        prev = slicer_second

        limit -= 5
    return _list, _list2

for r in alternator(OGlist):
    print("LIST =>", r)
# LIST => ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'AB', 'BB', 'CC', 'DD']
# LIST => [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
  1. В этом примере я использовал функцию itertools.count

  2. Позвоните Next на counting, чтобы получить 5, 10 и т. д..

  3. Из функции get_partition получаем срез элементов.

Другие вопросы по теме