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

Новый Dataframe с информацией из старого Dataframe

12.11.2021, 17:24. Показов 5864. Ответов 5

Студворк — интернет-сервис помощи студентам
У меня есть такой Dataframe.

4444.xlsx


Мне нужно посчитать количество каждого значения из столбца Message для каждого номера из столбца Number по-отдельности и создать новый Dataframe используя эту информацию. Первый столбец нового Dataframe должен содержать все номера из колонки Number, остальные столбцы - все виды сообщений из Message. Я разобралась, как мне посчитать все эти значения для всех номеров по-отдельности. Для этого я использую следующий фрагмент кода

Python
1
2
grouped = df1['Message'].groupby(df1['Number'])
grouped.value_counts()


Но не могу разобраться, как мне эту информацию поместить в новый Dataframe в том формате, как описано выше. Когда я добавляю grouped.value_counts() в конструктор при создании Dataframe, выходит вот это:



Чтобы создать шапку для моей новой таблицы, могу ли я использовать этот фрагмент кода?

Python
1
message = list(df1['Message'].unique())
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
12.11.2021, 17:24
Ответы с готовыми решениями:

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

DataFrame
Как работает двоеточие в данном случае? (не то что оно делает, а с точки зрения языка) В офф документации только примеры использования,...

Pandas (DataFrame)
Как считать большой файл частями и записать применяя фильтр как считать частями я понял: pd.read_csv(doc_red, encoding='utf8',...

5
enx
 Аватар для enx
1189 / 765 / 277
Регистрация: 05.09.2021
Сообщений: 1,772
12.11.2021, 17:48
TamaraTam, вот честное слово, я бы тебе помог, если бы ты выложил примеры текстом в спойлерах. Что за привычка блин кидать скрины данных? Может код тоже ответом в скрине послать?
0
0 / 0 / 0
Регистрация: 08.11.2021
Сообщений: 6
12.11.2021, 19:26  [ТС]
Так там же табличка екселевская с данными специально прикреплена перед скрином со странным названием 4444.xlsx.Думала, что этого достаточно. Я тут новенькая...
0
enx
 Аватар для enx
1189 / 765 / 277
Регистрация: 05.09.2021
Сообщений: 1,772
12.11.2021, 19:42
TamaraTam, вопрос не к табличке xlsx, а к выводу условных 'ошибок'.

Добавлено через 25 секунд
И общему коду, который применяется.
0
0 / 0 / 0
Регистрация: 08.11.2021
Сообщений: 6
15.11.2021, 16:14  [ТС]
enx, вот код, который применяется (работаю в Jupyter Notebook)

Python
1
2
3
4
5
6
7
8
9
10
df1 = pd.read_excel("4444.xlsx")
 
# считаю значения для всех номеров по-отдельности
grouped = df1['Message'].groupby(df1['Number'])
grouped.value_counts()
 
# пытаюсь создать новый DataFrame, но с этим кодом выходит не так как хотелось бы
df1_new = pd.DataFrame(grouped.value_counts())
df1_new.columns = ['Count']
df1_new
Хотелось бы вот такую табличку, заполненную количесвом значений Message для каждого Number:

NumberStartjuaoanythingEndkoKOoltostplozono
1             
2             
3             
4             
5             
0
Эксперт Python
8837 / 4489 / 1864
Регистрация: 27.03.2020
Сообщений: 7,311
15.11.2021, 18:50
Лучший ответ Сообщение было отмечено TamaraTam как решение

Решение

TamaraTam,
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
import pandas as pd
import numpy as np
tuples = list(zip(*[['917', '917', '937', '937', '906', '906', '800', '800'],
['one', 'three', 'one', 'two','one', 'three', 'one', 'two']]))
index = pd.MultiIndex.from_tuples(tuples, names=['numbers', 'message'])
 
df = pd.DataFrame(np.random.randint(1,4,8), index=index, columns=['count'])
print(df)
 
####################
df = df.unstack(level=-1)
print(df)
####################
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
15.11.2021, 18:50
Помогаю со студенческими работами здесь

Empty DataFrame
Пытаюсь найти confidence однако после запуска кода выдает то, что Empty DataFrame. Даже при Empty DataFrame. Ошибки не выбивает....

Сравнение в Dataframe
У меня есть вот такой датасет. Я привел данные к 1 типу str и если я делаю простую сверку, как на рисунке, то получаю True. Как я могу...

Чистка DataFrame
Есть большой ДФ. В нем пропуски и часто встречающаяся запись "For notes:". Необходимо очистить данные от пропусков. Из того, что я пишу,...

Визуализация DataFrame
Добрый день. Мне надо графически отобразить DataFrame так, чтобы по оси X были даты, а по оси Y - значения. Вот, что из себя представляет...

Работа в DataFrame
У меня есть дата-фрейм Надо пройтись по столбцу "Бонус для агента (руб.)" и убрать "руб.", что можно было все...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru