[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.축의 패치에서 직접 가져옵니다.
축의 패치에서 직접 가져옵니다.
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.메서드가있는 솔루션은 샘플 부동 소수점 서식을 사용하여 음수 값도 처리합니다.
메서드가있는 솔루션은 샘플 부동 소수점 서식을 사용하여 음수 값도 처리합니다.
여전히 미세 조정이 필요합니다.
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))
from https://stackoverflow.com/questions/25447700/annotate-bars-with-values-on-pandas-bar-plots by cc-by-sa and MIT license
'PYTHON' 카테고리의 다른 글
[PYTHON] if-return-return 또는 if-else-return을 사용하는 것이 더 효율적입니까? (0) | 2018.10.10 |
---|---|
[PYTHON] Pyspark가있는 Spark 데이터 프레임의 각 열에있는 NaN 이외의 항목 수 계산 (0) | 2018.10.10 |
[PYTHON] Celery (celerybeat)에 정기적 인 태스크를 동적으로 추가 / 제거하는 방법 (0) | 2018.10.10 |
[PYTHON] MySQL 데이터베이스에 데이터를 삽입하려면 어떻게해야합니까? (0) | 2018.10.10 |
[PYTHON] 파이썬에서 오버로드 된 함수? (0) | 2018.10.10 |