>  기사  >  백엔드 개발  >  Pandas 및 Matplotlib를 사용하여 Python에서 클러스터형 누적 막대 그래프를 만드는 방법은 무엇입니까?

Pandas 및 Matplotlib를 사용하여 Python에서 클러스터형 누적 막대 그래프를 만드는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-11-02 12:46:30279검색

How to Create Clustered Stacked Bar Plots in Python with Pandas and Matplotlib?

군집 누적 막대 그래프 생성

문제:

열과 인덱스가 동일한 데이터 프레임이 여러 개 있고 이를 수행하려고 합니다. 클러스터된 각 데이터 프레임의 데이터로 누적 막대 그래프를 생성합니다. 함께.

Pandas 및 Matplotlib를 사용한 솔루션:

  1. 데이터 프레임을 단일 데이터 프레임으로 결합합니다.
  2. 플롯_clustered_stacked() 함수를 사용하여 누적 막대 그래프를 생성합니다. 이 함수는 다음 인수를 사용합니다.

    • dfall: 플롯할 데이터 프레임 목록.
    • labels: 데이터 프레임 이름 목록(선택 사항).
    • title: 플롯 제목(선택 사항).
    • H: 각 데이터 프레임에 사용할 해치 패턴 (선택).

코드:

<code class="python">import pandas as pd
import matplotlib.cm as cm
import numpy as np
import matplotlib.pyplot as plt

def plot_clustered_stacked(dfall, labels=None, title=&quot;multiple stacked bar plot&quot;,  H=&quot;/&quot;, **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=&quot;bar&quot;,
                      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=&quot;gray&quot;, 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

# create fake dataframes
df1 = pd.DataFrame(np.random.rand(4, 5),
                   index=[&quot;A&quot;, &quot;B&quot;, &quot;C&quot;, &quot;D&quot;],
                   columns=[&quot;I&quot;, &quot;J&quot;, &quot;K&quot;, &quot;L&quot;, &quot;M&quot;])
df2 = pd.DataFrame(np.random.rand(4, 5),</code>

위 내용은 Pandas 및 Matplotlib를 사용하여 Python에서 클러스터형 누적 막대 그래프를 만드는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.