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

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

10.07.2022, 01:20. Показов 1043. Ответов 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
8849 / 4500 / 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
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru