> 백엔드 개발 > 파이썬 튜토리얼 > 단일 열을 기반으로 Pandas DataFrames의 3방향 조인을 수행하는 방법은 무엇입니까?

단일 열을 기반으로 Pandas DataFrames의 3방향 조인을 수행하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-12-01 05:32:14
원래의
802명이 탐색했습니다.

How to Perform a Three-Way Join of Pandas DataFrames Based on a Single Column?

열 기반 Pandas 데이터 프레임에서 3방향 조인 수행

서로 다른 데이터 세트로 작업할 때 이를 병합하여 포괄적인 보기를 얻을 수 있습니다. 결정적이다. Python의 pandas 라이브러리에서 Join() 함수는 공통 인덱스를 기반으로 여러 데이터프레임을 결합하는 강력한 방법을 제공합니다.

질문:

3개의 CSV 파일을 보유하고 있습니다. 각각은 첫 번째 열에 사람 이름을 포함하고 나머지 열에 다양한 속성을 포함합니다. 목표는 이러한 파일을 하나의 CSV로 "결합"하여 각 행이 고유한 사람과 모든 속성을 나타내는 것입니다.

처음에 Join() 함수는 다중 인덱스가 필요함을 의미합니다. 그러나 단일 인덱스를 기반으로 조인하려고 하면 혼란이 발생합니다.

답변:

원하는 3방향 조인을 달성하려면 functools를 사용할 수 있습니다. 데이터 프레임에 대한 순차적 축소 작업을 용이하게 하는 축소 기능입니다. 수행 방법은 다음과 같습니다.

import functools as ft
dfs = [df0, df1, df2, ..., dfN]  # List of dataframes
df_final = ft.reduce(lambda left, right: pd.merge(left, right, on='name'), dfs)
로그인 후 복사

이 접근 방식을 사용하면 '이름'과 같은 공통 열을 기반으로 임의 수의 데이터 프레임을 병합할 수 있습니다. Reduce() 함수는 pandas merge() 함수를 목록의 데이터 프레임에 반복적으로 적용하여 병합된 모든 속성 데이터를 포함하는 df_final이라는 단일 데이터 프레임을 생성합니다.

위 내용은 단일 열을 기반으로 Pandas DataFrames의 3방향 조인을 수행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿