Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 16.05.2018
Сообщений: 105

Агрегация для dataframe

22.11.2023, 19:10. Показов 437. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день !!

Подскажите как бы вы реализовали в Python следующую задачу:

Есть таблица с данными, которую нужно дополнить строчкой с итогами.
Данные представлены как в прикрепе.
Для агрегации необходимо использовать столбец "Участник".

Столбцы для которых необходимо вернуть значение в строке "Итоги":

CntChng - отношение (sum(Cnt)-sum(CntPrev))/sum(CntPrev)
position - sum(position)
PD - avg(PD)


В данный момент смотрю функции pd.pivot_table() и pd.crosstab()

ОГРОМНОЕ СПАСИБО!
Вложения
Тип файла: xlsx Q1.xlsx (11.0 Кб, 4 просмотров)
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
22.11.2023, 19:10
Ответы с готовыми решениями:

Структура JSON для pandas dataframe
Здравствуйте. Есть есть сервис который присылает json на python сервер (сервер python на dash для отображения данных). Какая должна...

Новый Dataframe с информацией из старого Dataframe
У меня есть такой Dataframe. Мне нужно посчитать количество каждого значения из столбца Message для каждого номера из...

Pandas. Изменение значений Dataframe исходя из другого Dataframe
Добрый день. Прошу подсказать с реализаций следующего алгоритма: я загружаю из файла примерно следующий Dataframe(db): ...

3
Эксперт Python
8851 / 4502 / 1864
Регистрация: 27.03.2020
Сообщений: 7,317
22.11.2023, 20:04
Иван_777, как вариант:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
import pandas as pd
 
df = pd.read_excel('/content/drive/MyDrive/Q1.xlsx', nrows=12, dtype='str')
df[['Cnt','CntPrev','position']] = df[['Cnt','CntPrev','position']].astype('int32')
df
 
for elem in df['Участник '].unique():
  df_ = df[df['Участник ']==elem]
  dct = {'AssName': 'ИТОГО',
         'CntChng': (df_['Cnt'].sum() - df_['CntPrev'].sum())/df_['CntPrev'].sum(),
         'position' : df_['position'].sum(),
         'PD': df_['PD'].astype('float').mean().round(2)}
  df_ = df_.append(dct,ignore_index=True)
  print(df_)
1
0 / 0 / 0
Регистрация: 16.05.2018
Сообщений: 105
22.11.2023, 20:31  [ТС]
Спасибо огромное! А что здесь происходит не могли бы пояснить.

Цитата Сообщение от Gdez Посмотреть сообщение
df_ = df[df['Участник ']==elem]
0
Эксперт Python
8851 / 4502 / 1864
Регистрация: 27.03.2020
Сообщений: 7,317
22.11.2023, 21:17
Иван_777, отбираются строки, в которых по столбцу «Участник » значение равно текущему значению elem
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
22.11.2023, 21:17
Помогаю со студенческими работами здесь

Как задать границы для ввода данных DataFrame
Доброго времени суток ! Хочу использовать ексель для ввода данных. Скажите плз как задать границы для ввода данных data_pd =...

pandas - подготовить dataframe для загрузки в реляционную СУБД
Добрый день! Есть dataframe с 4 полями-категориями. Как выделить категории в отдельные dataframe, поместив в первоначальном индексы? ...

Список List добавить в pd.DataFrame для сохранения в таблицу excel
Парсил ресурс - буржуйский инет - каталог. Получение данных - все прошло. Но появился вопрос. Как добавить список(cards) в моем случае в...

Как задать условие для замены слов в тексте (DataFrame Python)
Привет всем! Вопрос по проекту для курса который я сейчас прохожу. У меня имеется следующий аутпут по столбцу "цель оформления...

Агрегация
Здравствуйте. Небольшой вопрос касательно агрегации: может ли объект быть агрегирован одновременно в 2х и более других объектов, или...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Контроль корректности заполнения дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru