<p id="m2nkj"><option id="m2nkj"><big id="m2nkj"></big></option></p>
    <strong id="m2nkj"></strong>
    <ruby id="m2nkj"></ruby>

    <var id="m2nkj"></var>
  • Python Matplotlib小技巧!

    共 11565字,需瀏覽 24分鐘

     ·

    2023-10-23 21:16

    點擊上方小白學(xué)視覺”,選擇加"星標(biāo)"或“置頂

        
        
    重磅干貨,第一時間送達(dá)

    本文介紹Python Matplotlib實用小技巧!

    1. 添加標(biāo)題-title
    matplotlib.pyplot 對象中有個 title() 可以設(shè)置表格的標(biāo)題。
       
       
    import numpy as np
    import matplotlib.pyplot as plt
    # 顯示中文
    plt.rcParams['font.sans-serif'] = [u'SimHei']
    plt.rcParams['axes.unicode_minus'] = False
    %matplotlib inline
    x=np.arange(0,10)
    plt.title('這是一個示例標(biāo)題')
    plt.plot(x,x*x)
    plt.show()

    具體實現(xiàn)效果:


    2. 添加文字-text

    設(shè)置坐標(biāo)和文字,可以使用 matplotlib.pyplot 對象中 text() 接口。其中 第一、二個參數(shù)來設(shè)置坐標(biāo),第三個參數(shù)是設(shè)置顯示文本內(nèi)容。

       
       
    import numpy as np
    import matplotlib.pyplot as plt
    # 顯示中文
    plt.rcParams['font.sans-serif'] = [u'SimHei']
    plt.rcParams['axes.unicode_minus'] = False
    %matplotlib inline
    x=np.arange(-10,11,1)
    y=x*x
    plt.plot(x,y)
    plt.title('這是一個示例標(biāo)題')
    # 添加文字
    plt.text(-2.5,30,'function y=x*x')
    plt.show()
    具體實現(xiàn)效果:

    3. 添加注釋-annotate


    我們實用 annotate() 接口可以在圖中增加注釋說明。其中:
    • xy 參數(shù):備注的坐標(biāo)點

    • xytext 參數(shù):備注文字的坐標(biāo)(默認(rèn)為xy的位置)

    • arrowprops 參數(shù):在 xy 和 xytext 之間繪制一個箭頭。

       
       
    import numpy as np
    import matplotlib.pyplot as plt
    # 顯示中文
    plt.rcParams['font.sans-serif'] = [u'SimHei']
    plt.rcParams['axes.unicode_minus'] = False
    %matplotlib inline
    x=np.arange(-10,11,1)
    y=x*x
    plt.title('這是一個示例標(biāo)題')
    plt.plot(x,y)
    # 添加注釋
    plt.annotate('這是一個示例注釋',xy=(0,1),xytext=(-2,22),arrowprops={'headwidth':10,'facecolor':'r'})
    plt.show()
    具體實現(xiàn)效果:


    4. 設(shè)置坐標(biāo)軸名稱-xlabel/ylabel

    二維坐標(biāo)圖形中,需要在橫軸和豎軸注明名稱以及數(shù)量單位。設(shè)置坐標(biāo)軸名稱使用的接口是 xlabel() 和 ylable()。

       
       
    import numpy as np
    import matplotlib.pyplot as plt
    # 顯示中文
    plt.rcParams['font.sans-serif'] = [u'SimHei']
    plt.rcParams['axes.unicode_minus'] = False
    %matplotlib inline
    x=np.arange(1,20)
    plt.xlabel('示例x軸')
    plt.ylabel('示例y軸')
    plt.plot(x,x*x)
    plt.show()
    具體實現(xiàn)效果:

    5. 添加圖例-legend

    當(dāng)線條過多時,我們設(shè)置不同顏色來區(qū)分不同線條。因此,需要對不同顏色線條做下標(biāo)注,我們實用 legend() 接口來實現(xiàn)。

       
       
    import numpy as np
    import matplotlib.pyplot as plt
    # 顯示中文
    plt.rcParams['font.sans-serif'] = [u'SimHei']
    plt.rcParams['axes.unicode_minus'] = False
    %matplotlib inline
    plt.plot(x,x)
    plt.plot(x,x*2)
    plt.plot(x,x*3)
    plt.plot(x,x*4)
    # 直接傳入legend
    plt.legend(['生活','顏值','工作','金錢'])
    plt.show()
    具體實現(xiàn)效果:

    6. 調(diào)整顏色-color

    傳顏色參數(shù),使用 plot() 中的 color 屬性來設(shè)置,color 支持以下幾種方式。
       
       
    import numpy as np
    import matplotlib.pyplot as plt
    %matplotlib inline
    x=np.arange(1,5)
    #顏色的幾種方式
    plt.plot(x,color='g')
    plt.plot(x+1,color='0.5')
    plt.plot(x+2,color='#FF00FF')
    plt.plot(x+3,color=(0.1,0.2,0.3))
    plt.show()
    具體實現(xiàn)效果:

    7. 切換線條樣式-marker

    如果想改變線條的樣式,我們可以使用修改 plot() 繪圖接口中 mark 參數(shù),具體實現(xiàn)效果:
       
       
    import numpy as np
    import matplotlib.pyplot as plt
    %matplotlib inline
    x=np.arange(1,5)
    plt.plot(x,marker='o')
    plt.plot(x+1,marker='>')
    plt.plot(x+2,marker='s')
    plt.show()

    具體實現(xiàn)效果

    其中 marker 支持的類型:

    • ‘.’:點(point marker)

    • ‘,’:像素點(pixel marker)

    • ‘o’:圓形(circle marker)

    • ‘v’:朝下三角形(triangle_down marker)

    • ‘^’:朝上三角形(triangle_up marker)

    • ‘<‘:朝左三角形(triangle_left marker)

    • ‘>’:朝右三角形(triangle_right marker)

    • ‘1’:(tri_down marker)

    • ‘2’:(tri_up marker)

    • ‘3’:(tri_left marker)

    • ‘4’:(tri_right marker)

    • ‘s’:正方形(square marker)

    • ‘p’:五邊星(pentagon marker)

    • ‘*’:星型(star marker)

    • ‘h’:1號六角形(hexagon1 marker)

    • ‘H’:2號六角形(hexagon2 marker)

    • ‘+’:+號標(biāo)記(plus marker)

    • ‘x’:x號標(biāo)記(x marker)

    • ‘D’:菱形(diamond marker)

    • ‘d’:小型菱形(thin_diamond marker)

    • ‘|’:垂直線形(vline marker)

    • ‘_’:水平線形(hline marker)


    具體各個效果類型如下:

    8. 顯示數(shù)學(xué)公式-mathtext

    格式如下:作為開始和結(jié)束符,如$,中間的將解析出公式中的符號。
       
       
    import numpy as np
    import matplotlib.pyplot as plt
    %matplotlib inline
    plt.title('chenqionghe')
    plt.xlim([1,8])
    plt.ylim([1,5])
    plt.text(2,4,r'$ \alpha \beta \pi \lambda \omega $',size=25)
    plt.text(4,4,r'$ \sin(0)=\cos(\frac{\pi}{2}) $',size=25)
    plt.text(2,2,r'$ \lim_{x \rightarrow y} \frac{1}{x^3} $',size=25)
    plt.text(4,2,r'$ \sqrt[4]{x}=\sqrt{y} $',size=25)
    plt.show()
    具體實現(xiàn)效果:


    9. 顯示網(wǎng)格-grid

    grid() 接口可以用來設(shè)置背景圖為網(wǎng)格。
       
       
    import numpy as np
    import matplotlib.pyplot as plt
    %matplotlib inline
    x='a','b','c','d'
    y=[15,30,45,10]
    plt.grid()
    # 也可以設(shè)置顏色、線條寬度、線條樣式
    # plt.grid(color='g',linewidth='1',linestyle='-.')
    plt.plot(x,y)
    plt.show()

    具體實現(xiàn)效果:


    10. 調(diào)整坐標(biāo)軸刻度-locator_params

    坐標(biāo)圖的刻度我們可以使用 locator_params 接口來調(diào)整顯示顆粒。
    同時調(diào)整 x 軸和 y 軸:plt.locator_params(nbins=20)
    只調(diào)整 x 軸:plt.locator_params(‘'x',nbins=20)
    只調(diào)整 y 軸:plt.locator_params(‘'y',nbins=20)
       
       
    import numpy as np
    import matplotlib.pyplot as plt
    %matplotlib inline
    x=np.arange(0,30,1)
    plt.plot(x,x)
    # x軸和y軸分別顯示20個
    plt.locator_params(nbins=20)
    plt.show()

    具體實現(xiàn)效果:

    11. 調(diào)整坐標(biāo)軸范圍-axis/xlim/ylim

    axis:[0,5,0,10],x從0到5,y從0到10

    xlim:對應(yīng)參數(shù)有xmin和xmax,分別能調(diào)整最大值最小值
    ylim:同xlim用法
       
       
    import numpy as np
    import matplotlib.pyplot as plt
    %matplotlib inline
    x=np.arange(0,30,1)
    plt.plot(x,x*x)
    #顯示坐標(biāo)軸,plt.axis(),4個數(shù)字分別代表x軸和y軸的最小坐標(biāo),最大坐標(biāo)
    #調(diào)整x為10到25
    plt.xlim(xmin=10,xmax=25)
    plt.plot(x,x*x)
    plt.show()

    具體實現(xiàn)效果:

    12. 調(diào)整日期自適應(yīng)-autofmt_xdate

    有時候顯示日期會重疊在一起,非常不友好,調(diào)用plt.gcf().autofmt_xdate(),將自動調(diào)整角度。
       
       
    import numpy as np
    import pandas as pd
    import matplotlib.pyplot as plt
    %matplotlib inline
    x=pd.date_range('2020/01/01',periods=30)
    y=np.arange(0,30,1)
    plt.plot(x,y)
    plt.gcf().autofmt_xdate()
    plt.show()
    具體實現(xiàn)效果:


    13. 添加雙坐標(biāo)軸-twinx

       
       
    import numpy as np
    import matplotlib.pyplot as plt
    %matplotlib inline
    x=np.arange(1,20)
    y1=x*x
    y2=np.log(x)
    plt.plot(x,y1)
    # 添加一個坐標(biāo)軸,默認(rèn)0到1
    plt.twinx()
    plt.plot(x,y2,'r')
    plt.show()
    具體實現(xiàn)效果:

    14. 填充區(qū)域-fill/fill_beween

    fill 填充函數(shù)區(qū)域

       
       
    import numpy as np
    import matplotlib.pyplot as plt
    # 顯示中文
    plt.rcParams['font.sans-serif'] = [u'SimHei']
    plt.rcParams['axes.unicode_minus'] = False
    %matplotlib inline
    x=np.linspace(0,5*np.pi,1000)
    y1=np.sin(x)
    y2=np.sin(2*x)
    plt.plot(x,y1)
    plt.plot(x,y2)
    # 填充
    plt.fill(x,y1,'g')
    plt.fill(x,y2,'r')
    plt.title('這是一個示例標(biāo)題')
    plt.show()
    具體實現(xiàn)效果:

    fill_beween填充函數(shù)交叉區(qū)域
       
       
    import numpy as np
    import matplotlib.pyplot as plt
    # 顯示中文
    plt.rcParams['font.sans-serif'] = [u'SimHei']
    plt.rcParams['axes.unicode_minus'] = False
    %matplotlib inline
    plt.title('這是一個示例標(biāo)題')
    x=np.linspace(0,5*np.pi,1000)
    y1=np.sin(x)
    y2=np.sin(2*x)
    plt.plot(x,y1)
    plt.plot(x,y2)
    # 填充
    plt.fill_between(x,y1,y2,where=y1>y2,interpolate=True)
    plt.show()
    具體實現(xiàn)效果:

    15. 畫一個填充好的形狀-matplotlib.patche

       
       
    import numpy as np
    import matplotlib.pyplot as plt
    import matplotlib.patches as mptaches
    %matplotlib inline
    xy1=np.array([0.2,0.2])
    xy2=np.array([0.2,0.8])
    xy3=np.array([0.8,0.2])
    xy4=np.array([0.8,0.8])
    fig,ax=plt.subplots()
    #圓形,指定坐標(biāo)和半徑
    circle=mptaches.Circle(xy1,0.15)
    ax.add_patch(circle)
    #長方形
    rect=mptaches.Rectangle(xy2,0.2,0.1,color='r')
    ax.add_patch(rect)
    #多邊形
    polygon=mptaches.RegularPolygon(xy3,6,0.1,color='g')
    ax.add_patch(polygon)
    # 橢圓
    ellipse=mptaches.Ellipse(xy4,0.4,0.2,color='c')
    ax.add_patch(ellipse)
    ax.axis('equal')
    plt.show()

    具體實現(xiàn)效果:

    16. 切換樣式-plt.style.use

    matplotlib支持多種樣式,可以通過plt.style.use切換樣式,例如:
    plt.style.use('ggplot')輸入plt.style.available 可以查看所有的樣式:
       
       
    import matplotlib.pyplot as plt
    plt.style.available
    具體實現(xiàn)效果:


    示例代碼,ggplot樣式:
       
       
    import numpy as np
    import matplotlib.pyplot as plt
    import matplotlib.patches as mptaches
    %matplotlib inline
    plt.style.use('ggplot')
    # 新建4個子圖
    fig,axes=plt.subplots(2,2)
    ax1,ax2,ax3,ax4=axes.ravel()
    # 第一個圖
    x,y=np.random.normal(size=(2,100))
    ax1.plot(x,y,'o')
    # 第二個圖
    x=np.arange(0,10)
    y=np.arange(0,10)
    colors=plt.rcParams['axes.prop_cycle']
    length=np.linspace(0,10,len(colors))
    for s in length:
       ax2.plot(x,y+s,'-')
    # 第三個圖
    x=np.arange(5)
    y1,y2,y3=np.random.randint(1,25,size=(3,5))
    width=0.25
    ax3.bar(x,y1,width)
    ax3.bar(x+width,y2,width)
    ax3.bar(x+2*width,y3,width)
    # 第四個圖
    for i,color in enumerate(colors):
       xy=np.random.normal(size=2)
    ax4.add_patch(plt.Circle(xy,radius=0.3,color=color['color']))
    ax4.axis('equal')
    plt.show()
    具體實現(xiàn)效果:

    -END-

    10W字《Python可視化教程1.0》來了!??

       
       
    下載1:OpenCV-Contrib擴(kuò)展模塊中文版教程
    在「小白學(xué)視覺」公眾號后臺回復(fù):擴(kuò)展模塊中文教程,即可下載全網(wǎng)第一份OpenCV擴(kuò)展模塊教程中文版,涵蓋擴(kuò)展模塊安裝、SFM算法、立體視覺、目標(biāo)跟蹤、生物視覺、超分辨率處理等二十多章內(nèi)容。

    下載2:Python視覺實戰(zhàn)項目52講
    小白學(xué)視覺公眾號后臺回復(fù):Python視覺實戰(zhàn)項目,即可下載包括圖像分割、口罩檢測、車道線檢測、車輛計數(shù)、添加眼線、車牌識別、字符識別、情緒檢測、文本內(nèi)容提取、面部識別等31個視覺實戰(zhàn)項目,助力快速學(xué)校計算機視覺。

    下載3:OpenCV實戰(zhàn)項目20講
    小白學(xué)視覺公眾號后臺回復(fù):OpenCV實戰(zhàn)項目20講,即可下載含有20個基于OpenCV實現(xiàn)20個實戰(zhàn)項目,實現(xiàn)OpenCV學(xué)習(xí)進(jìn)階。

    交流群


    歡迎加入公眾號讀者群一起和同行交流,目前有SLAM、三維視覺、傳感器自動駕駛、計算攝影、檢測、分割、識別、醫(yī)學(xué)影像、GAN、算法競賽等微信群(以后會逐漸細(xì)分),請掃描下面微信號加群,備注:”昵稱+學(xué)校/公司+研究方向“,例如:”張三 + 上海交大 + 視覺SLAM“。請按照格式備注,否則不予通過。添加成功后會根據(jù)研究方向邀請進(jìn)入相關(guān)微信群。請勿在群內(nèi)發(fā)送廣告,否則會請出群,謝謝理解~


    瀏覽 705
    點贊
    評論
    收藏
    分享

    手機掃一掃分享

    分享
    舉報
    評論
    圖片
    表情
    推薦
    點贊
    評論
    收藏
    分享

    手機掃一掃分享

    分享
    舉報
    <p id="m2nkj"><option id="m2nkj"><big id="m2nkj"></big></option></p>
    <strong id="m2nkj"></strong>
    <ruby id="m2nkj"></ruby>

    <var id="m2nkj"></var>
  • 黄色大电影在这 | 亚洲精品手机在线 | 黄片子视频 | 伊人网在线观看 | 欧美色影院 | 天天射天天拍 | 日本人 毛茸茸 护士 | 日本精品一字幕 | 黄片黄片黄片黄片黄片黄片黄片 | 五月天三级片 |