データ分析と可視化
25921 ワード
13.円図(デフォルト)
14.円図(深化)
14-1. DataFrameの利用
import matplotlib.pyplot as plt
import matplotlib
matplotlib.rcParams['font.family'] = 'Malgun Gothic' #windows
matplotlib.rcParams['font.size'] = 15
matplotlib.rcParams['axes.unicode_minus'] = False
values = [30, 25, 20, 13, 10, 2]
labels = ['Python', 'Java', 'Javascript', "C#", 'C/C++', 'ETC']
plt.pie(values, labels=labels, autopct = '%.1f%%', startangle=90, counterclock=False)
#퍼센트를 기준으로 나눠서 나타냄
#%%를 두번써주면 뒤에 %까지 붙음
#startangle은 기준을 중간 90도부터 시계반대방향으로
#시계방향으로 설정하고 싶으면 counterclock사용
plt.show()
data:image/s3,"s3://crabby-images/f5bc0/f5bc0f8323891af54c0fa7445c275db4e20e7a0d" alt=""
values = [30, 25, 20, 13, 10, 2]
labels = ['Python', 'Java', 'Javascript', "C#", 'C/C++', 'ETC']
#explode = [0.2, 0.1, 0, 0, 0, 0] #간격띄우기
explode = [0.05]*6 #동일간격 띄우기
plt.pie(values, labels=labels, explode = explode)
plt.show()
data:image/s3,"s3://crabby-images/39c2b/39c2b9600141a08b44bd92edb691d3b6f3dd29c8" alt=""
plt.pie(values, labels=labels, explode = explode)
plt.legend(loc=(1.2, 0.3))
plt.show()
data:image/s3,"s3://crabby-images/61a6c/61a6c2490a4e3c054d1e3098e7a520bf5e62f111" alt=""
plt.pie(values, labels=labels, explode = explode)
plt.title('언어별 선호도')
plt.legend(loc=(1.2, 0.3), title='언어')
plt.show()
data:image/s3,"s3://crabby-images/4b45e/4b45ea28a085ba77669b49da92d4c4236bbd939b" alt=""
14.円図(深化)
import matplotlib.pyplot as plt
import matplotlib
matplotlib.rcParams['font.family'] = 'Malgun Gothic' #windows
matplotlib.rcParams['font.size'] = 15
matplotlib.rcParams['axes.unicode_minus'] = False
values = [30, 25, 20, 13, 10, 2]
labels = ['Python', 'Java', 'Javascript', "C#", 'C/C++', 'ETC']
#colors = ['b', 'g', 'r','c', 'm', 'y']
colors = ['#ffadad', '#ffd6a5', '#fdffb6', '#caffbf', '#9bf6ff', '#a0c4ff']
explode = [0.05]*6
plt.pie(values, labels=labels, autopct = '%.1f%%', startangle=90, counterclock=False, colors= colors, explode = explode)
plt.show()
data:image/s3,"s3://crabby-images/28a31/28a3173ee4807ad501aa5cf3e89469cb1af7260a" alt=""
wedgeprops = {'width':0.6}
plt.pie(values, labels=labels, autopct = '%.1f%%', startangle=90, counterclock=False, colors= colors, explode = explode, wedgeprops=wedgeprops)
plt.show()
data:image/s3,"s3://crabby-images/37bde/37bde354c8482bb331c4e22f31862c0ad110f9a9" alt=""
wedgeprops = {'width':0.6, 'edgecolor':'w', 'linewidth':3}
plt.pie(values, labels=labels, autopct = '%.1f%%', startangle=90, counterclock=False, colors= colors, wedgeprops=wedgeprops)
plt.show()
data:image/s3,"s3://crabby-images/1bd62/1bd6223f43178678c4f923000459d023db25882d" alt=""
def custom_autopct(pct):
return ('%.1f%%' % pct) if pct >= 10 else ''
plt.pie(values, labels=labels, autopct = custom_autopct, startangle=90, counterclock=False, colors= colors, wedgeprops=wedgeprops)
plt.show()
data:image/s3,"s3://crabby-images/a8bc3/a8bc3d06b9e6aace90388f08b842f73fb62a195d" alt=""
#방법2
def custom_autopct(pct):
return '{:.1f}%'.format(pct) if pct >=10 else ''
plt.pie(values, labels=labels, autopct = custom_autopct, startangle=90, counterclock=False, colors= colors, wedgeprops=wedgeprops)
plt.show()
data:image/s3,"s3://crabby-images/871eb/871ebde4304ed29df9a61d6c25e687622fb034d8" alt=""
# 정수부분만 출력
def custom_autopct(pct):
return '{:.0f}%'.format(pct) if pct >=10 else ''
plt.pie(values, labels=labels, autopct = custom_autopct, startangle=90, counterclock=False, colors= colors, wedgeprops=wedgeprops)
plt.show()
data:image/s3,"s3://crabby-images/4b3d7/4b3d7236716aaba0ae4172c76ea69e9cc548b6eb" alt=""
#숫자 거리띄우기
def custom_autopct(pct):
return '{:.0f}%'.format(pct) if pct >=10 else ''
plt.pie(values, labels=labels, autopct = custom_autopct, startangle=90, counterclock=False, colors= colors, wedgeprops=wedgeprops, pctdistance=0.7)
plt.show()
data:image/s3,"s3://crabby-images/48b44/48b4452cdb3c3a479403960f06e019a5e888ffc4" alt=""
14-1. DataFrameの利用
import pandas as pd
df = pd.read_excel('../Pandas/score3.xlsx')
df
data:image/s3,"s3://crabby-images/65fc2/65fc222c17819642abf1a669d25f19b278b78e88" alt=""
#학교대비 학생수
grp = df.groupby('학교')
grp
>>>
<pandas.core.groupby.generic.DataFrameGroupBy object at 0x00000205FA4755E0>
grp.size()
data:image/s3,"s3://crabby-images/b75de/b75de9bbf6c7e819e3441cb7268675519534f547" alt=""
grp.size()['북산고']
>>> 5
grp.size()['능남고']
>>> 3
values = [grp.size()['북산고'], grp.size()['능남고']] #[5,3]
labels =['북산고', '능남고']
plt.pie(values, labels=labels)
plt.title('소속학교')
plt.show()
data:image/s3,"s3://crabby-images/59f93/59f931208cc7d827d4394af1461c740dbb9dd3b3" alt=""
Reference
この問題について(データ分析と可視化), 我々は、より多くの情報をここで見つけました https://velog.io/@ssjy89/나도코딩-데이터-분석-및-시각화-Matplotlib6テキストは自由に共有またはコピーできます。ただし、このドキュメントのURLは参考URLとして残しておいてください。
Collection and Share based on the CC Protocol