1 / 2 / 0
Регистрация: 06.09.2019
Сообщений: 18

Объединение таблиц

10.07.2022, 01:20. Показов 1061. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый ночи, киберчане! Не подскажите, в чем ошибке в коде ниже и как пофиксить? Есть 5 датасэтов, мне нужно объединить все. Сначала объединяю 1 и 2 - все работает. При дальнейшем объединение происходит ошибка.

Python
1
2
3
data = data_users.set_index('user_id').join(data_calls.set_index('user_id'))
data = data.set_index('user_id').join(data_messages.set_index('user_id')) # если эту строку закоментить, все сработает
data.head(10)
Код ошибки прикладываю скрином
Миниатюры
Объединение таблиц  
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
10.07.2022, 01:20
Ответы с готовыми решениями:

Объединение Excel таблиц
Доброго времени суток! Мне нужно соединить две таблицы в одну, чтобы из одной брались данные и вставлялись в другую. При соединении...

Объединение двух таблиц (запрос на объединение)
В аналогичных темах не нашел решения. Возможно кто-то сможет помочь в решении следующей задачи: Есть таблицы (f_2021, f_2022 ) их...

Объединение данных из нескольких таблиц одинаковых таблиц
Добрый день! Помогите с запросом есть у меня таблицы которые имеют одинаковую структуры полей Есть вариант упростить запрос, если у...

6
Эксперт Python
 Аватар для Red white socks
4523 / 1899 / 336
Регистрация: 18.01.2021
Сообщений: 3,489
10.07.2022, 02:37
'user_id' в data это не имя столбца, а имя индекса. Поэтому set_index вызывает ошибку.
1
1 / 2 / 0
Регистрация: 06.09.2019
Сообщений: 18
10.07.2022, 13:52  [ТС]
А можно пофиксить? Как сделать, чтобы user_id вновь стал именем столбца?
0
Эксперт Python
 Аватар для Red white socks
4523 / 1899 / 336
Регистрация: 18.01.2021
Сообщений: 3,489
10.07.2022, 14:44
Цитата Сообщение от DesignerPRO Посмотреть сообщение
Как сделать, чтобы user_id вновь стал именем столбца?
Python
1
data.reset_index()
Но лучше просто лишний set_index убрать
2
1 / 2 / 0
Регистрация: 06.09.2019
Сообщений: 18
15.07.2022, 22:41  [ТС]
reset_index() помог спасибо! Но почему дальше таблицы не соединяются?

Python
1
2
3
4
data = data_users.set_index('user_id').join(data_calls.set_index('user_id'))
data = data.reset_index()
#data = data.set_index('user_id').join(data_messages.set_index('user_id'))
data.head(10)
Если раскоментить 3-ю строку, происходить ошибка? Во вложении прикреплю, что хранится в data и data_messages и скрин ошибки
Миниатюры
Объединение таблиц   Объединение таблиц   Объединение таблиц  

0
Эксперт Python
 Аватар для Red white socks
4523 / 1899 / 336
Регистрация: 18.01.2021
Сообщений: 3,489
16.07.2022, 00:57
DesignerPRO, столбец id есть в обоих таблицах.
Либо переименуйте, либо используйте в join параметр lsuffix или rsuffix

Добавлено через 7 минут
Цитата Сообщение от DesignerPRO Посмотреть сообщение
Python
1
2
data = data.reset_index()
data = data.set_index('user_id')
Убираете индекс и тут же ставите его снова.
Ошибки нет, но вопрос об адекватности поднимает
1
Эксперт Python
8850 / 4501 / 1864
Регистрация: 27.03.2020
Сообщений: 7,316
16.07.2022, 05:33
Можно через merge
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
import pandas as pd 
import numpy as np 
 
left = pd.DataFrame({'key': [1,2,3,4,5,6], 'id': [2,3,4,22,33,44], 'l': [100,200,300,400,500,600]})
right = pd.DataFrame({'key': [1,2,3], 'id': [2,3,4], 'r': [4, 5, 6]})
right_1 = pd.DataFrame({'key': [4,5,6], 'id': [22,33,44], 'r': [7,8,9]})
print(left)
print(right)
print(right_1)
print()
 
left = left.merge(right, how='outer', on=['key','id'])
print(left)
left = left.merge(right_1, how='outer', on=['key','id'])
print(left)
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
16.07.2022, 05:33
Помогаю со студенческими работами здесь

Объединение таблиц (внешнее объединение)
Подскажите как правильно выполнить запрос объединения таблиц? Допустим есть у меня 2 таблицы: (* - ключ) 1) Клиенты - *код_клиенты...

Объединение таблиц
Помогите пожалуйста, никак не могу разобраться. Существуют таблицы например tab1 столбцы (kat, nom, kol)o b 5 b j 7 o k 7 tab2...

Объединение таблиц
Здравствуйте! Возможно как-то соединить две таблицы по одинаковым полям, но чтобы данные в других полях не задваивались? SELECT...

Объединение таблиц
Подскажите что не так в запросе? SELECT s.fio, s.pol, s.dr, s.adres st.street FROM stud s LEFT OUTER JOIN street st ON...

Объединение таблиц
Здравствуйте, не могу связать правильно таблицы. Суть такова: Пользователь, представитель фирмы, авторизуется н асайте и получает...


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

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

Новые блоги и статьи
Символьное дифференцирование
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