복붙노트

[PYTHON] 판다 막대 막대에 막대 값에 주석 달기

PYTHON

판다 막대 막대에 막대 값에 주석 달기

내 DataFrame에서 반올림 된 숫자 값이있는 판다 막대 막대에 내 막대에 주석을 추가하는 방법을 찾고있었습니다.

>>> df=pd.DataFrame({'A':np.random.rand(2),'B':np.random.rand(2)},index=['value1','value2'] )         
>>> df
                 A         B
  value1  0.440922  0.911800
  value2  0.588242  0.797366

나는 이와 같은 것을 얻고 싶다 :

이 코드 샘플을 사용해 보았지만 주석은 모두 x ticks에 집중되었습니다.

>>> ax = df.plot(kind='bar') 
>>> for idx, label in enumerate(list(df.index)): 
        for acc in df.columns:
            value = np.round(df.ix[idx][acc],decimals=2)
            ax.annotate(value,
                        (idx, value),
                         xytext=(0, 15), 
                         textcoords='offset points')

해결법

  1. ==============================

    1.축의 패치에서 직접 가져옵니다.

    축의 패치에서 직접 가져옵니다.

    In [35]: for p in ax.patches:
        ax.annotate(str(p.get_height()), (p.get_x() * 1.005, p.get_height() * 1.005))
    

    당신은 문자열 포맷팅과 오프셋을 꼬집어서 물건 중심에 놓기를 원할 것입니다. 아마도 p.get_width ()에서 너비를 사용할 수 있습니다.하지만 시작해야합니다. 어딘가에서 오프셋을 추적하지 않으면 누적 가로 막 대형 영역에서 작동하지 않을 수 있습니다.

  2. ==============================

    2.메서드가있는 솔루션은 샘플 부동 소수점 서식을 사용하여 음수 값도 처리합니다.

    메서드가있는 솔루션은 샘플 부동 소수점 서식을 사용하여 음수 값도 처리합니다.

    여전히 미세 조정이 필요합니다.

    df=pd.DataFrame({'A':np.random.rand(2)-1,'B':np.random.rand(2)},index=['val1','val2'] )
    ax = df.plot(kind='bar', color=['r','b']) 
    x_offset = -0.03
    y_offset = 0.02
    for p in ax.patches:
        b = p.get_bbox()
        val = "{:+.2f}".format(b.y1 + b.y0)        
        ax.annotate(val, ((b.x0 + b.x1)/2 + x_offset, b.y1 + y_offset))
    

  3. from https://stackoverflow.com/questions/25447700/annotate-bars-with-values-on-pandas-bar-plots by cc-by-sa and MIT license