102 / 85 / 25
Регистрация: 21.05.2019
Сообщений: 481

Группировка списка по неделям

15.07.2022, 16:30. Показов 1041. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет, есть список

Python
1
lst = [["2022-07-15", 1, 2, 3], ["2022-07-15", 2, 3, 4], ["2022-06-29", 1, 2, 3], ["2022-07-07", 2, 3, 4]]
На выходе хочу получить, список, где первый элемент это первый день в неделе, и если два элемента в одной неделе, то просуммировать их значения
Python
1
>> [["2022-07-11", 3, 5, 7], ["2022-06-27", 1, 2, 3], ["2022-07-04", 2, 3, 4]]
И тоже самое для группировке по месяцам
Python
1
>> [["2022-07", 5, 8, 11], ["2022-06", 1, 2, 3]]
Добавлено через 9 минут
Сам я вот такой способ для группировки по неделям придумаю, но думаю есть оптимальнее

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
import datetime
 
data = [["2022-07-15", 1, 2, 3], ["2022-07-15", 2, 3, 4], ["2022-06-29", 1, 2, 3], ["2022-07-07", 2, 3, 4]]
 
# Добавляем номер недели в список
for i in data:
    date = i[0].split("-")
    year, month, day = date
    i.append(datetime.date(int(year), int(month), int(day)).isocalendar()[1])
 
res = []
for i in data:
    for j in res:
        if i[4] == j[4]:
            j[1] += i[1]
            j[2] += i[2]
            j[3] += i[3]
            break
    else:
        res.append(i)
 
print(res)
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
15.07.2022, 16:30
Ответы с готовыми решениями:

Группировка списка
Подскажите, пожалуйста, как мне сгруппировать такой список? ,,,,,] Что бы получилось Москва Значение1 Значение2 ...

Группировка по неделям
Есть таблица Продаж Date---------Price 01.02.17----10 02.02.17----20 02.02.17----10 04.02.17----20 05.02.17----10 ...

Группировка по неделям!
существует таблица (датаплатежа, суммаплатежа)... необходимо сделать отчет по сумме платежей понедельно... как можно решить эту проблему? ...

1
Эксперт по компьютерным сетям
 Аватар для Jabbson
5907 / 3359 / 1036
Регистрация: 03.11.2009
Сообщений: 10,008
15.07.2022, 17:23
Лучший ответ Сообщение было отмечено RSAX как решение

Решение

Python
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
from datetime import datetime, timedelta
from itertools import groupby
 
lst = [["2022-07-15", 1, 2, 3], ["2022-07-15", 2, 3, 4], ["2022-06-29", 1, 2, 3], ["2022-07-07", 2, 3, 4]]
lst = sorted(lst, key=lambda x: x[0])
 
def get_fdow(d_str):
    dt = datetime.strptime(d_str, '%Y-%m-%d').date()    
    w_start = str(dt - timedelta(days=dt.weekday()))
    return w_start
 
def get_fdom(d_str):
    dt = datetime.strptime(d_str, '%Y-%m-%d').date()
    return dt.strftime('%Y-%m')
 
def group_elements(group_func):
    new_lst = []                                            
    for k, g in groupby(lst, key=lambda x: group_func(x[0])): 
        sub = [k]                                           
        for x in zip(*(x[1:] for x in g)):                  
            sub.append(sum(x))                              
        new_lst.append(sub)
    return new_lst
 
print(group_elements(get_fdow))
print(group_elements(get_fdom))
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
15.07.2022, 17:23
Помогаю со студенческими работами здесь

Группировка списка
Как в Visual Studio сделать группировку списка как на этой картинке?

Группировка в форме списка
всем привет! сделал группировку в форме списка по дате, а как мне сделать чтобы программно ветка даты была закрыта а не открыта код: ...

Группировка строка в таблице списка
Всем доброго времени суток. Как сделать так, чтобы строки с одинаковой датой и временем группировались в одну?

Группировка элементов списка запросом
Доброго времени суток. Только изучаю c#. Делаю лабораторные. Из-за отсутствия некоторых знаний, не могу выполнить задание. Само задание...

Автоматическая группировка по значению списка
Добрый день, прошу помочь с макросом. Файл во вложении, задача: 1 выбор значения в списке (B2) "НЕТ" - открывает только...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Программа принимает математическое выражение в виде строки и выдаёт его производную в виде строки и вычисляет значение производной при заданном х Логарифм записывается как: (x-2)log(x^2+2) -. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru