Python에서 여러 DataFrame에 대한 클러스터형 누적 막대 차트를 만드는 방법은 무엇입니까?
Nov 02, 2024 pm 07:07 PM여러 데이터프레임에 대한 클러스터형 누적 막대 차트 생성
문제 설명
동일한 열과 인덱스가 있는 여러 데이터프레임을 처리할 때 다음을 수행하는 것이 바람직할 수 있습니다. 클러스터형 누적 막대 차트를 만들어 데이터를 시각화합니다. 각 데이터프레임에 대한 막대를 해당 인덱스별로 그룹화하여 별도로 쌓으려고 할 때 문제가 발생합니다.
Pandas 및 Matplotlib를 사용한 솔루션
Pandas와 Matplotlib의 조합을 사용하면 이를 달성할 수 있습니다. 막대 직사각형의 위치와 해칭 패턴을 수동으로 조정합니다. 자세한 솔루션은 다음과 같습니다.
<code class="python">import pandas as pd import numpy as np import matplotlib.pyplot as plt def plot_clustered_stacked(dfall, labels=None, title="multiple stacked bar plot", H="/" , **kwargs): n_df = len(dfall) n_col = len(dfall[0].columns) n_ind = len(dfall[0].index) axe = plt.subplot(111) for df in dfall: # for each data frame axe = df.plot(kind="bar", linewidth=0, stacked=True, ax=axe, legend=False, grid=False, **kwargs) # make bar plots h, l = axe.get_legend_handles_labels() # get the handles we want to modify for i in range(0, n_df * n_col, n_col): # len(h) = n_col * n_df for j, pa in enumerate(h[i:i+n_col]): for rect in pa.patches: # for each index rect.set_x(rect.get_x() + 1 / float(n_df + 1) * i / float(n_col)) rect.set_hatch(H * int(i / n_col)) #edited part rect.set_width(1 / float(n_df + 1)) axe.set_xticks((np.arange(0, 2 * n_ind, 2) + 1 / float(n_df + 1)) / 2.) axe.set_xticklabels(df.index, rotation = 0) axe.set_title(title) # Add invisible data to add another legend n=[] for i in range(n_df): n.append(axe.bar(0, 0, color="gray", hatch=H * i)) l1 = axe.legend(h[:n_col], l[:n_col], loc=[1.01, 0.5]) if labels is not None: l2 = plt.legend(n, labels, loc=[1.01, 0.1]) axe.add_artist(l1) return axe</code>
로그인 후 복사
Seaborn을 사용한 솔루션
Seaborn의 막대 그래프 기능을 사용하면 누적 막대 차트를 만들 수 있지만 기본적으로 다양한 데이터 프레임에 대한 막대를 누적할 수는 없습니다. 이 문제를 극복하기 위해 다음 해결 방법을 사용할 수 있습니다.
- pd.melt()를 사용하여 데이터프레임을 "정돈된" 형식으로 변환합니다.
- 다음을 사용하여 각 막대의 누적 합계를 계산합니다. groupby 및 cumsum()을 사용하여 vcs라는 새 열을 만듭니다.
- 변수 그룹을 반복하고 sns.barplot()을 사용하여 누적 합계를 그립니다.
<code class="python">import seaborn as sns # Convert dataframes to tidy format dfall.set_index([&quot;Name&quot;, &quot;index&quot;, &quot;variable&quot;], inplace=1) dfall[&quot;vcs&quot;] = dfall.groupby(level=[&quot;Name&quot;, &quot;index&quot;]).cumsum() dfall.reset_index(inplace=True) # Create color palette c = [&quot;blue&quot;, &quot;purple&quot;, &quot;red&quot;, &quot;green&quot;, &quot;pink&quot;] # Iterate through groups and plot stacked bars for i, g in enumerate(dfall.groupby(&quot;variable&quot;)): ax = sns.barplot(data=g[1], x=&quot;index&quot;, y=&quot;vcs&quot;,</code>
로그인 후 복사
위 내용은 Python에서 여러 DataFrame에 대한 클러스터형 누적 막대 차트를 만드는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

인기 기사
스플릿 소설을이기는 데 얼마나 걸립니까?
3 몇 주 전
By DDD
Repo : 팀원을 부활시키는 방법
3 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌
헬로 키티 아일랜드 어드벤처 : 거대한 씨앗을 얻는 방법
3 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌

인기 기사
스플릿 소설을이기는 데 얼마나 걸립니까?
3 몇 주 전
By DDD
Repo : 팀원을 부활시키는 방법
3 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌
헬로 키티 아일랜드 어드벤처 : 거대한 씨앗을 얻는 방법
3 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 기사 태그

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제
Gmail 이메일의 로그인 입구는 어디에 있나요?
7281
9


자바 튜토리얼
1622
14


Cakephp 튜토리얼
1341
46


라라벨 튜토리얼
1258
25


PHP 튜토리얼
1205
29



Tensorflow 또는 Pytorch로 딥 러닝을 수행하는 방법은 무엇입니까?
