• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    Python 数据科学 Matplotlib图库详解

    Matplotlib 是 Python 的二维绘图库,用于生成符合出版质量或跨平台交互环境的各类图形。

    图形解析与工作流

    图形解析 

    工作流

    Matplotlib 绘图的基本步骤:
    1  准备数据

    2  创建图形

    3 绘图

    4 自定义设置

    5 保存图形

    6 显示图形

    import matplotlib.pyplot as plt
    x = [1,2,3,4] # step1
    y = [10,20,25,30]
    fig = plt.figure() # step2
    ax = fig.add_subplot(111) # step3
    ax.plot(x, y, color='lightblue', linewidth=3) # step3\4
    ax.scatter([2,4,6], 
                [5,15,25], 
                color='darkgreen', 
                marker='^')
    ax.set_xlim(1, 6.5)
    plt.savefig('foo.png') # step5
    plt.show() # step6

     

    准备数据

    一维数据

    import numpy as np
     
    x = np.linspace(0, 10, 100)
    y = np.cos(x) 
    z = np.sin(x)

    二维数据或图片

    data = 2 * np.random.random((10, 10))
    data2 = 3 * np.random.random((10, 10))
    Y, X = np.mgrid[-3:3:100j, -3:3:100j]
    U = -1 - X**2 + Y
    V = 1 + X - Y**2
    from matplotlib.cbook import get_sample_data
    img = np.load('E:/anaconda3/envs/torch/Lib/site-packages/matplotlib/mpl-data/aapl.npz')

    绘制图形

    import matplotlib.pyplot as plt

    画布

    fig = plt.figure()
    fig2 = plt.figure(figsize=plt.figaspect(2.0))

    坐标轴

    图形是以坐标轴为核心绘制的,大多数情况下,子图就可以满足需求。子图是栅格系统的坐标轴。

    fig.add_axes()
    ax1 = fig.add_subplot(221) # row-col-num
    ax3 = fig.add_subplot(212) 
    fig3, axes = plt.subplots(nrows=2,ncols=2)
    fig4, axes2 = plt.subplots(ncols=3)

    绘图例程

    一维数据

    fig, ax = plt.subplots()
    lines = ax.plot(x,y) # 用线或标记连接点
    ax.scatter(x,y) # 缩放或着色未连接的点
    axes[0,0].bar([1,2,3],[3,4,5]) # 绘制等宽纵向矩形
    axes[1,0].barh([0.5,1,2.5],[0,1,2]) # 绘制等高横向矩形
    axes[1,1].axhline(0.45) # 绘制与轴平行的横线
    axes[0,1].axvline(0.65) # 绘制与轴垂直的竖线
    ax.fill(x,y,color='blue') # 绘制填充多边形
    ax.fill_between(x,y,color='yellow') # 填充y值和0之间

    二维数据或图片

    import matplotlib.image as imgplt
    img = imgplt.imread('C:/Users/Administrator/Desktop/timg.jpg')
     
    fig, ax = plt.subplots()
    im = ax.imshow(img, cmap='gist_earth', interpolation='nearest', vmin=-200, vmax=200)# 色彩表或RGB数组
     
    axes2[0].pcolor(data2) # 二维数组伪彩色图
    axes2[0].pcolormesh(data) # 二维数组等高线伪彩色图
    CS = plt.contour(Y,X,U) # 等高线图
    axes2[2].contourf(data)     
    axes2[2]= ax.clabel(CS) # 等高线图标签

    向量场

    axes[0,1].arrow(0,0,0.5,0.5) # 为坐标轴添加箭头
    axes[1,1].quiver(y,z) # 二维箭头
    axes[0,1].streamplot(X,Y,U,V) # 二维箭头

    数据分布

    ax1.hist(y) # 直方图
    ax3.boxplot(y) # 箱形图
    ax3.violinplot(z) # 小提琴图

    自定义图形 颜色、色条与色彩表

    plt.plot(x, x, x, x**2, x, x**3)
    ax.plot(x, y, alpha = 0.4)
    ax.plot(x, y, c='k')
    fig.colorbar(im, orientation='horizontal')
    im = ax.imshow(img,                  
                    cmap='seismic')

    标记

    fig, ax = plt.subplots()
    ax.scatter(x,y,marker=".")
    ax.plot(x,y,marker="o")

    线型

    plt.plot(x,y,linewidth=4.0)
    plt.plot(x,y,ls='solid') 
    plt.plot(x,y,ls='--')
    plt.plot(x,y,'--',x**2,y**2,'-.')
    plt.setp(lines,color='r',linewidth=4.0)

    文本与标注

    ax.text(1, 
            -2.1,
            'Example Graph',
            style='italic')
    ax.annotate("Sine",
                xy=(8, 0), 
                xycoords='data',
                xytext=(10.5, 0), 
                textcoords='data',
                arrowprops=dict(arrowstyle="->",
                connectionstyle="arc3"),)

    数学符号

    plt.title(r'$sigma_i=15$', fontsize=20)

    尺寸限制、图例和布局

    尺寸限制与自动调整

    ax.margins(x=0.0,y=0.1) # 添加内边距
    ax.axis('equal') # 将图形纵横比设置为1
    ax.set(xlim=[0,10.5],ylim=[-1.5,1.5]) # 设置x轴与y轴的限
    ax.set_xlim(0,10.5)

    图例

    ax.set(title='An Example Axes',
           ylabel='Y-Axis',  
           xlabel='X-Axis') # 设置标题与x、y轴的标签
    ax.legend(loc='best') # 自动选择最佳的图例位置

    标记

    ax.xaxis.set(ticks=range(1,5),
                ticklabels=[3,100,-12,"foo"]) # 手动设置X轴刻度
    ax.tick_params(axis='y',                     
                    direction='inout', 
                    length=10) # 设置Y轴长度与方向

    子图间距

    fig3.subplots_adjust(wspace=0.5,
                        hspace=0.3,
                        left=0.125, 
                        right=0.9, 
                        top=0.9, 
                        bottom=0.1)
    fig.tight_layout() # 设置画布的子图布局

    坐标轴边线

    ax1.spines['top'].set_visible(False) # 隐藏顶部坐标轴线
    ax1.spines['bottom'].set_position(('outward',10)) # 设置底部边线的位置为outward

    保存

    #保存画布
    plt.savefig('foo.png')
    # 保存透明画布
    plt.savefig('foo.png', transparent=True)

    显示图形

    plt.show()

    关闭与清除

    plt.cla() # 清除坐标轴
    plt.clf() #  清除画布
    plt.close() # 关闭窗口

    以上就是Python 数据科学 Matplotlib的详细内容,更多关于Python 数据科学 Matplotlib的资料请关注脚本之家其它相关文章!

    您可能感兴趣的文章:
    • Python heapq库案例详解
    • python数据库如何连接SQLite详解
    • python实现图像处理之PiL依赖库的案例应用详解
    • python中的tkinter库弹窗messagebox详解
    • python数据可视化plt库实例详解
    • 一篇文章带你详细了解python中一些好用的库
    上一篇:Python3中最常用的5种线程锁实例总结
    下一篇:Python制作一个随机抽奖小工具的实现
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    Python 数据科学 Matplotlib图库详解 Python,数据,科学,Matplotlib,