欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python之 matplotlib和pandas繪圖教程

 更新時(shí)間:2021年03月08日 15:55:45   作者:layman2016  
這篇文章主要介紹了python之 matplotlib和pandas繪圖教程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

不得不說(shuō)使用python庫(kù)matplotlib繪圖確實(shí)比較丑,但使用起來(lái)還算是比較方便,做自己的小小研究可以使用。這里記錄一些統(tǒng)計(jì)作圖方法,包括pandas作圖和plt作圖。

前提是先導(dǎo)入第三方庫(kù)吧

import pandas as pd
import matplotlib.pyplot as plt
import numpy as np

然后以下這兩句用于正常顯示中文標(biāo)簽什么的。

plt.rcParams['font.sans-serif'] = ['SimHei'] # 用來(lái)正常顯示中文標(biāo)簽
plt.rcParams['axes.unicode_minus'] = False # 用來(lái)正常顯示負(fù)號(hào)

當(dāng)然還有一些最基本的步驟:

plt.xticks(x,xtk,size=12,rotation=50) #設(shè)置字體大小和字體傾斜度
plt.xlabel(u'城市') # x軸標(biāo)簽
plt.ylabel(u'數(shù)量')
plt.title(u'朋友所在城市') # 圖的名稱
plt.legend() # 正常顯示標(biāo)題
plt.show() # 顯示圖像
plt.close() # 繪圖后養(yǎng)成習(xí)慣性的關(guān)掉

對(duì)于pandas中的二維數(shù)據(jù)框,可以直接作圖(Series類型),簡(jiǎn)單的折線圖或者曲線圖如下:

sdata.plot(color='r', style='-o')
plt.show()

如果沒(méi)有用pandas,直接作曲線圖,可以這樣寫(xiě):

plot(x,y, color ='blue', linewidth=2.5, linestyle="--")

1,柱狀圖

rects1=plt.bar(           #(x,data) 就是所要畫(huà)的二維數(shù)據(jù)
    left=x,           #x 是X坐標(biāo)軸數(shù)據(jù),即每個(gè)塊的x軸起始位置
    height=data,         #data是Y坐標(biāo)軸的數(shù)據(jù),即每個(gè)塊的y軸高度
    width=[0.1,0.2,0.3],     #每一個(gè)塊的顯示寬度
    bottom=[1,2,3],       #每一個(gè)塊的底部高度
    color='y',          #塊的顏色
    edgecolor='g',        #塊的邊界顏色
    linewidth=2,         #塊的線條寬度
    xerr=1,           #x軸誤差bar
    yerr=1,           #y軸誤差bar
    ecolor='r',         #誤差bar的顏色
    capsize=1,          #誤差bar的線條寬度
    orientation='vertical',   #塊的方向 (horizontal,vertical)
    align="center",       #塊的位置 (center, left, right)
    hold=None
    )
 
plt.show()

2,餅圖

plot2=plt.pie(data,             # 每個(gè)餅塊的實(shí)際數(shù)據(jù),如果大于1,會(huì)進(jìn)行歸一化,計(jì)算percentage
    explode=[0.0,0.1,0.2],        # 每個(gè)餅塊離中心的距離
    colors=['y','r','g'],        # 每個(gè)餅塊的顏色
    labels=['women','men','unknown'],  # 每個(gè)餅塊的標(biāo)簽
    labeldistance=1.2,          # 每個(gè)餅塊標(biāo)簽到中心的距離
    autopct='%1.1f%%',         # 百分比的顯示格式
    pctdistance=0.4,           # 百分比到中心的距離
    shadow=True,             # 每個(gè)餅塊是否顯示陰影
    startangle=0,            # 默認(rèn)從x軸正半軸逆時(shí)針起
    radius=1.0              # 餅塊的半徑
    )
plt.axis('equal') # 顯示為圓形,避免比例壓縮為橢圓
plt.show()

3,共享X軸,Y軸左右軸標(biāo)(帕累托分析圖)

數(shù)據(jù)樣例如下,名稱為va,類型為Series,左邊為職位名稱,右邊為數(shù)量:

sales     4140
technical   2720
support    2229
IT       1227
product_mng   902
marketing    858
RandD      787
accounting   767
hr       739
management   630

作圖:

fr = pd.Series(va.values.cumsum() / va.values.sum())
va.plot(kind='bar')
fr.plot(color='r',secondary_y=True, style='-o')
plt.annotate(format(fr[7], '.2%'), xy=(7, fr[7]), xytext=(7*0.9, fr[7]*0.9),
       arrowprops=dict(arrowstyle='->', connectionstyle='arc3,rad=.2')) # 用于注釋圖形指標(biāo)
# plt.rcParams['font.sans-serif'] = ['SimHei'] # 用來(lái)正常顯示中文標(biāo)簽
# plt.rcParams['axes.unicode_minus'] = False # 用來(lái)正常顯示負(fù)號(hào)
# plt1 = plt.pie(va.values,
#        labels=va.index,
#        autopct='%1.1f%%')
plt.xticks(rotation=50) # 設(shè)置字體大小和字體傾斜度
plt.show()

左邊為出現(xiàn)的頻率,右邊為累積百分比(這里數(shù)據(jù)以降序排列較好,便于直觀地觀察),效果如下:

在pandas中,曲線圖可以直接畫(huà),比如data中有多個(gè)屬性,可以直接使用data.plot()。使用plt,若各個(gè)屬性需要共用XY軸,那么可以重復(fù)plot即可。

4,箱型圖

使用pandas畫(huà)箱型圖簡(jiǎn)單方便,但是注釋比較麻煩,可以用annotate添加異常點(diǎn)的注釋。若使用之前的數(shù)據(jù)va,則先創(chuàng)建二維數(shù)據(jù)框再畫(huà)圖。如果有多個(gè)列為數(shù)字類型,那么可以畫(huà)每個(gè)列的箱型圖,這里只有一列數(shù)據(jù),如下:

pd.DataFrame(va).boxplot()
plt.show()

使用plt直接進(jìn)行作圖:

plt.boxplot(data,labels=[],
     sym='o',whis=1.5)

其中,data可以是一維的,也可多維,若為多維則lables為每一維度的標(biāo)簽。sym為異常值的形狀,whis為調(diào)節(jié)垂直線段的長(zhǎng)度。效果如下:

5,多張圖在一張畫(huà)布中,即多個(gè)子圖

使用plt:

plt.subplot(221)
plt.plot(x, y1,'r-', lw=2) 
plt.subplot(222)
plt.plot(x,y2)

使用pandas:

data.plot(subplots=True, color=['r','b'], style=['-o','-'])
plt.show()

排版方式有不同,pandas是垂直排列,plt可以自己指定位置。pandas效果如下:

補(bǔ)充:Python DataFrame 多條件篩選 使用&

我就廢話不多說(shuō)了,大家還是直接看代碼吧~

DF6
Out[42]: 
 B C D
0 1 B 10.750
1 3 C 8.875
2 2 T 58.000
3 2 L 57.000
4 3 Y 46.000
DF6[(DF6.B>1) & (DF6.D > 10)]
Out[45]: 
 B C D
2 2 T 58.0
3 2 L 57.0
4 3 Y 46.0

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

相關(guān)文章

  • python中watchdog文件監(jiān)控與檢測(cè)上傳功能

    python中watchdog文件監(jiān)控與檢測(cè)上傳功能

    這篇文章主要介紹了python中watchdog文件監(jiān)控與檢測(cè)上傳功能,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-10-10
  • 將python圖片轉(zhuǎn)為二進(jìn)制文本的實(shí)例

    將python圖片轉(zhuǎn)為二進(jìn)制文本的實(shí)例

    今天小編就為大家分享一篇將python圖片轉(zhuǎn)為二進(jìn)制文本的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-01-01
  • Python保存MongoDB上的文件到本地的方法

    Python保存MongoDB上的文件到本地的方法

    這篇文章主要介紹了Python保存MongoDB上的文件到本地的方法,涉及Python調(diào)用pymongo模塊的gridfs方法來(lái)操作MongoDB文件的相關(guān)技巧,需要的朋友可以參考下
    2016-03-03
  • Python3匿名函數(shù)lambda介紹與使用示例

    Python3匿名函數(shù)lambda介紹與使用示例

    這篇文章主要給大家介紹了關(guān)于Python3匿名函數(shù)lambda與使用的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Python3具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • Pytest allure 命令行參數(shù)的使用

    Pytest allure 命令行參數(shù)的使用

    這篇文章主要介紹了Pytest allure 命令行參數(shù)的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • scrapy spider的幾種爬取方式實(shí)例代碼

    scrapy spider的幾種爬取方式實(shí)例代碼

    這篇文章主要介紹了scrapy spider的幾種爬取方式實(shí)例代碼,小編覺(jué)得還是挺不錯(cuò)的,具有一定借鑒價(jià)值,需要的朋友可以參考下
    2018-01-01
  • CentOS 7 安裝python3.7.1的方法及注意事項(xiàng)

    CentOS 7 安裝python3.7.1的方法及注意事項(xiàng)

    這篇文章主要介紹了CentOS 7 安裝python3.7.1的方法,文中給大家提到了注意事項(xiàng),需要的朋友可以參考下
    2018-11-11
  • Python實(shí)現(xiàn)字符串逆序輸出功能示例

    Python實(shí)現(xiàn)字符串逆序輸出功能示例

    這篇文章主要介紹了Python實(shí)現(xiàn)字符串逆序輸出功能,結(jié)合具體實(shí)例形式分析了Python針對(duì)字符串的遍歷、翻轉(zhuǎn)、排序等相關(guān)操作技巧,需要的朋友可以參考下
    2017-06-06
  • 對(duì)numpy中軸與維度的理解

    對(duì)numpy中軸與維度的理解

    下面小編就為大家分享一篇對(duì)numpy中軸與維度的理解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-04-04
  • Python對(duì)Excel不同的行分別復(fù)制不同的次數(shù)

    Python對(duì)Excel不同的行分別復(fù)制不同的次數(shù)

    這篇文章主要介紹了如何利用Python實(shí)現(xiàn)讀取Excel表格文件數(shù)據(jù),并將其中符合我們特定要求的那一行加以復(fù)制指定的次數(shù),感興趣的小伙伴可以學(xué)習(xí)一下
    2023-07-07

最新評(píng)論