99999久久久久久亚洲,欧美人与禽猛交狂配,高清日韩av在线影院,一个人在线高清免费观看,啦啦啦在线视频免费观看www

熱線電話:13121318867

登錄
首頁精彩閱讀python可視化:matplotlib繪制的餅狀圖你了解嗎?
python可視化:matplotlib繪制的餅狀圖你了解嗎?
2020-05-27
收藏

基于python數(shù)據(jù)可視化的繪圖系統(tǒng)matplotlib功能非常強大,按照國際慣例,寫在最開始的是對要介紹對象的定義。喏,這是從維基百科搬運過來的對餅圖的解釋,請安心受下:

餅圖,或稱餅狀圖,是一個劃分為幾個扇形的圓形統(tǒng)計圖表,用于描述量、頻率或百分比之間的相對關系。在餅圖中,每個扇區(qū)的弧長(以及圓心角和面積)大小為其所表示的數(shù)量的比例。這些扇區(qū)合在一起剛好是一個完全的圓形。顧名思義,這些扇區(qū)拼成了一個切開的餅形圖案。

當然,文字的解釋永遠沒有一個圖來的直觀:

基于Python的圖表繪圖系統(tǒng)<a href='/map/matplotlib/' style='color:#000;font-size:inherit;'>matplotlib</a>,“餅圖“”你真了解嗎?

這也是從維基百科上偷運過來的英語為母語的人口分布餅圖。不客氣的講,這個圖畫的相當簡陋,只能看出來一個大概的比例,像最后三個基本看不出來差別多有多少,所以我們在繪圖的時候盡量加上數(shù)量標簽,這樣一眼就能看得出來差距在哪里了。

畫一個餅圖

畫圖第一步是什么?當然是要數(shù)據(jù)啊,所有的圖都是對數(shù)據(jù)的一種展現(xiàn)形式而已!ok,先來看下我們的數(shù)據(jù)長什么樣子:

基于Python的圖表繪圖系統(tǒng)<a href='/map/matplotlib/' style='color:#000;font-size:inherit;'>matplotlib</a>,“餅圖“”你真了解嗎?

這是幾個學校語數(shù)外平均成績數(shù)據(jù)的前五行,整個數(shù)據(jù)源包含21條記錄,也就是有21個學校的平均成績信息,我們計劃查看其中一個學?;蛘邘讉€學校的成績餅圖。

先畫一個最簡單的餅圖看看效果:

plt.figure(figsize=(8,8),dpi=80) #新建畫布,由于餅圖是原型的,所以新建畫布為正方形 plt.pie(data2.iloc[0,1:] #選取數(shù)據(jù)源為第一小學的成績
        ,labels=['語文','數(shù)學','英語']) #設置每一角餅的標簽 plt.title('第1小學各學科成績占比',fontsize=12); #設置餅圖的標題和標題字號

效果圖如下:

基于Python的圖表繪圖系統(tǒng)<a href='/map/matplotlib/' style='color:#000;font-size:inherit;'>matplotlib</a>,“餅圖“”你真了解嗎?

是不是和維基百科搬運過來的餅圖很相像?還比那個多了個標題,嘿嘿…但是前邊說好的要顯示比例標簽呢?別急,其實可以設置的內容還有不少,不止是可以設置比例標簽呢!

完善餅圖

plt.figure(figsize=(8,8),dpi=80) #新建畫布 plt.pie(data2.iloc[0,1:]  #選取數(shù)據(jù)源
        ,labels=['語文','數(shù)學','英語'] #增加標簽
        ,autopct='%.2f%%' #設置百分比精度
        ,shadow=True  #顯示陰影,能夠增加立體感
        ,explode=[0.03,0.03,0.03]  #設置餅圖各個扇區(qū)之間的間隙
        ,colors=['r','g','b']) #設置餅圖各個扇區(qū)的顏色 plt.title('第1小學各學科成績占比',fontsize=12);

每行代碼的含義都以備注的方式解釋明白了,以上只是常用的參數(shù),當然還有一些不常用的參數(shù)并沒有全都一一試驗,給有好奇心的小可愛可以自行探索哈。

接下來查看效果的時間到了:

基于Python的圖表繪圖系統(tǒng)<a href='/map/matplotlib/' style='color:#000;font-size:inherit;'>matplotlib</a>,“餅圖“”你真了解嗎?

原諒我比較懶,沒有探索更好看的配色,直接粗暴的用了RGB(逃走)。

一次繪制多個餅圖

一次繪制多個餅圖其實對餅圖沒什么要求,只是需要添加幾個子圖而已!所謂子圖是相對于我們建立的整個畫布而言的,整個畫布相當與一張白紙,而子圖就相當于是給整張白紙進行了分區(qū),每個分區(qū)里邊放上一個完整的圖形:

pic2 = plt.figure(figsize=(8,8),dpi=80) #新建畫布,由于需要在畫布上增加子圖,所以講新建的畫布賦值一個變量名

fig1 = pic2.add_subplot(2,2,1) #第一個子圖(行數(shù),列數(shù),本子圖位置)
plt.pie(data2.iloc[0,1:] #選取數(shù)據(jù)源 第1小學各學科成績
        ,labels=['語文','數(shù)學','英語']
        ,autopct='%.2f%%' #設置百分比精度
        ,shadow=True #顯示陰影,增加立體感
        ,explode=[0.02,0.02,0.02])  #設置餅圖各個扇區(qū)之間的間隙
 #         ,colors=['r','g','b']) #設置餅圖各個扇區(qū)的顏色
plt.title('第1小學各學科成績占比',fontsize=12)#設置子圖的名稱

fig2 = pic2.add_subplot(2,2,2) #第二個字圖
plt.pie(data2.iloc[1,1:] #選取數(shù)據(jù)源,第2小學各學科成績
        ,labels=['語文','數(shù)學','英語']
        ,autopct='%.2f%%' #設置百分比精度
        ,shadow=True #顯示陰影,增加立體感
        ,explode=[0.02,0.02,0.02])  #設置餅圖各個扇區(qū)之間的間隙
 #         ,colors=['r','g','b']) #設置餅圖各個扇區(qū)的顏色
plt.title('第2小學各學科成績占比',fontsize=12)

fig3 = pic2.add_subplot(2,2,3) #第二個字圖
plt.pie(data2.iloc[2,1:] #選取數(shù)據(jù)源,第3小學各學科成績
        ,labels=['語文','數(shù)學','英語']
        ,autopct='%.2f%%' #設置百分比精度
        ,shadow=True #顯示陰影,增加立體感
        ,explode=[0.02,0.02,0.02])  #設置餅圖各個扇區(qū)之間的間隙
 #         ,colors=['r','g','b']) #設置餅圖各個扇區(qū)的顏色
plt.title('第3小學各學科成績占比',fontsize=12)

fig4 = pic2.add_subplot(2,2,4) #第二個字圖
plt.pie(data2.iloc[3,1:] #選取數(shù)據(jù)源,第4小學各學科成績
        ,labels=['語文','數(shù)學','英語']
        ,autopct='%.2f%%' #設置百分比精度
        ,shadow=True #顯示陰影,增加立體感
        ,explode=[0.02,0.02,0.02])  #設置餅圖各個扇區(qū)之間的間隙
 #         ,colors=['r','g','b']) #設置餅圖各個扇區(qū)的顏色
plt.title('第4小學各學科成績占比',fontsize=12);

添加子圖需要注意的是在新建畫布的時候,需要給畫布賦值一個變量名,方便添加子圖。另外添加幾個子圖一般是通過子圖的行數(shù)和列數(shù)來確定的,例如上邊代碼中是2行2列,即一共是4個子圖。

效果圖如下:

基于Python的圖表繪圖系統(tǒng)<a href='/map/matplotlib/' style='color:#000;font-size:inherit;'>matplotlib</a>,“餅圖“”你真了解嗎?

代碼中對顏色設定的部分被注釋掉了,所以這里的顏色是默認的顏色,美商高的小可愛們可以自行探索顏色的搭配。

matplotlib之餅圖,你學會了嗎?

數(shù)據(jù)分析咨詢請掃描二維碼

若不方便掃碼,搜微信號:CDAshujufenxi

數(shù)據(jù)分析師考試動態(tài)
數(shù)據(jù)分析師資訊
更多

OK
客服在線
立即咨詢
客服在線
立即咨詢
') } function initGt() { var handler = function (captchaObj) { captchaObj.appendTo('#captcha'); captchaObj.onReady(function () { $("#wait").hide(); }).onSuccess(function(){ $('.getcheckcode').removeClass('dis'); $('.getcheckcode').trigger('click'); }); window.captchaObj = captchaObj; }; $('#captcha').show(); $.ajax({ url: "/login/gtstart?t=" + (new Date()).getTime(), // 加隨機數(shù)防止緩存 type: "get", dataType: "json", success: function (data) { $('#text').hide(); $('#wait').show(); // 調用 initGeetest 進行初始化 // 參數(shù)1:配置參數(shù) // 參數(shù)2:回調,回調的第一個參數(shù)驗證碼對象,之后可以使用它調用相應的接口 initGeetest({ // 以下 4 個配置參數(shù)為必須,不能缺少 gt: data.gt, challenge: data.challenge, offline: !data.success, // 表示用戶后臺檢測極驗服務器是否宕機 new_captcha: data.new_captcha, // 用于宕機時表示是新驗證碼的宕機 product: "float", // 產品形式,包括:float,popup width: "280px", https: true // 更多配置參數(shù)說明請參見:http://docs.geetest.com/install/client/web-front/ }, handler); } }); } function codeCutdown() { if(_wait == 0){ //倒計時完成 $(".getcheckcode").removeClass('dis').html("重新獲取"); }else{ $(".getcheckcode").addClass('dis').html("重新獲取("+_wait+"s)"); _wait--; setTimeout(function () { codeCutdown(); },1000); } } function inputValidate(ele,telInput) { var oInput = ele; var inputVal = oInput.val(); var oType = ele.attr('data-type'); var oEtag = $('#etag').val(); var oErr = oInput.closest('.form_box').next('.err_txt'); var empTxt = '請輸入'+oInput.attr('placeholder')+'!'; var errTxt = '請輸入正確的'+oInput.attr('placeholder')+'!'; var pattern; if(inputVal==""){ if(!telInput){ errFun(oErr,empTxt); } return false; }else { switch (oType){ case 'login_mobile': pattern = /^1[3456789]\d{9}$/; if(inputVal.length==11) { $.ajax({ url: '/login/checkmobile', type: "post", dataType: "json", data: { mobile: inputVal, etag: oEtag, page_ur: window.location.href, page_referer: document.referrer }, success: function (data) { } }); } break; case 'login_yzm': pattern = /^\d{6}$/; break; } if(oType=='login_mobile'){ } if(!!validateFun(pattern,inputVal)){ errFun(oErr,'') if(telInput){ $('.getcheckcode').removeClass('dis'); } }else { if(!telInput) { errFun(oErr, errTxt); }else { $('.getcheckcode').addClass('dis'); } return false; } } return true; } function errFun(obj,msg) { obj.html(msg); if(msg==''){ $('.login_submit').removeClass('dis'); }else { $('.login_submit').addClass('dis'); } } function validateFun(pat,val) { return pat.test(val); }