zoukankan      html  css  js  c++  java
  • plt.figure() 和plt.subplot() 的用法

    一、plt.figure(num=None, figsize=None, dpi=None, facecolor=None, edgecolor=None, frameon=True) 

    方便连续画几个图片

    参数说明:

    1.num:图像编码或者名称,数字是编码,字符串是名称

    2.figsize:宽和高,单位是英尺

    3.dpi:指定绘图对象的分辨率,即每英寸多少个像素,缺省值为80 

    4.facecolor:背景颜色

    5.edgecolor:边框颜色

    6.frameon:是否显示边框

    例子:

    import warnings
    warnings.filterwarnings('ignore')
    
    import pandas as pd
    import numpy as np
    import matplotlib.pyplot as plt
    import seaborn as sns
    import scipy.stats as st
    Train_data =pd.read_csv('F:\python\天池_二手车交易价格预测\used_car_train_20200313.csv',sep=' ')
    y = Train_data['price']
    plt.figure(1); plt.title('Johnson SU')
    sns.distplot(y, kde=False, fit=st.johnsonsu)
    plt.figure(2); plt.title('Normal')
    sns.distplot(y, kde=False, fit=st.norm)
    plt.figure(3); plt.title('Log Normal')
    sns.distplot(y, kde=False, fit=st.lognorm)

    结果就可以一下子跑几个图片了

     

     

     二、plt.subplots(nrows,ncols,sharex,sharey,subplot_kw,**fig_kw)

    subplot可以规划figure划分为n个子图,但每条subplot命令只会创建一个子图

    参数说明:

    1.nrows:行数

    2.ncols:列数

    3.sharex:和谁共享x轴

    4.sharey:和谁共享y轴

    5.subplot_kw:关键字字典

    6.**fig_kw:其他关键字

    #1.plt.subplot(ijn)形式,其中ij是行列数,n是第几个图,比如(221)则是一个有四个图,该图位于第一个
    
    import numpy as np  
    import matplotlib.pyplot as plt  
    x = np.arange(0, 100)  
    #作图1
    plt.subplot(221)  
    plt.plot(x, x)  
    #作图2
    plt.subplot(222)  
    plt.plot(x, -x)  
     #作图3
    plt.subplot(223)  
    plt.plot(x, x ** 2)  
    plt.grid(color='r', linestyle='--', linewidth=1,alpha=0.3)
    #作图4
    plt.subplot(224)  
    plt.plot(x, np.log(x))  
    plt.show()  
    
    
    #又或者是这样
    import numpy as np  
    import matplotlib.pyplot as plt  
    x = np.arange(0, 100)  
    #作图1
    plt.subplot(331)  
    plt.plot(x, x)  
    #作图2
    plt.subplot(332)  
    plt.plot(x, -x)  
     #作图3
    plt.subplot(333)  
    plt.plot(x, x ** 2)  
    plt.grid(color='r', linestyle='--', linewidth=1,alpha=0.3)

    #2.fig,axes=plt.subplots(n,n)
    import numpy as np  
    import matplotlib.pyplot as plt
    
    x = np.arange(0, 100)  
    #划分子图
    fig,axes=plt.subplots(2,2)
    ax1=axes[0,0]
    ax2=axes[0,1]
    ax3=axes[1,0]
    ax4=axes[1,1]
    
    
    #作图1
    ax1.plot(x, x)  
    #作图2
    ax2.plot(x, -x)
     #作图3
    ax3.plot(x, x ** 2)
    ax3.grid(color='r', linestyle='--', linewidth=1,alpha=0.3)
    #作图4
    ax4.plot(x, np.log(x))  
    plt.show() 

    还可以是这种

    import numpy as np  
    import matplotlib.pyplot as plt
    
    x = np.arange(0, 100)  
    fig, ((ax1, ax2), (ax3, ax4)) = plt.subplots(nrows=2, ncols=2, figsize=(10, 10))
    #作图1
    ax1.plot(x, x)  
    #作图2
    ax2.plot(x, -x)
     #作图3
    ax3.plot(x, x ** 2)
    ax3.grid(color='r', linestyle='--', linewidth=1,alpha=0.3)
    #作图4
    ax4.plot(x, np.log(x))  
    plt.show() 

    #或者是这种:用sns中的ax=ax1
    import numpy as np  
    import matplotlib.pyplot as plt
    import seaborn as sns
    x = np.arange(0, 100)  
    fig, ((ax1, ax2), (ax3, ax4)) = plt.subplots(nrows=2, ncols=2, figsize=(10, 10))
    
    #作图1
    sns.regplot(x, x,ax=ax1)  
    #作图2
    sns.regplot(x, -x,ax=ax2)
     #作图3
    sns.regplot(x, x ** 2,ax=ax3);
    #作图4
    sns.regplot(x, np.log(x),ax=ax4)  
    plt.show() 

    使用for循环画图

    #还是使用前面的Train_data,实现对v_的字段画条形图
    n_cols=[i for i in Train_data.columns if i[:2]== 'v_']
    n_cols=['v_0','v_1','v2'] #简单跑一下算了
    for i ,col in enumerate(n_cols): plt.subplot(3,1,i+1) sns.barplot(x=col,y='price',data=Train_data) plt.title(('%s') % col)
  • 相关阅读:
    《最优化导论》-8梯度方法
    《最优化导论》-7一维搜索方法
    《最优化导论》-6集合约束和无约束优化问题基础
    ubuntu set up 3
    ubuntu set up 2
    ubuntu set up 1
    Xavier and Kaiming Initialization
    Network Initialization: Fan-in and Fan-out
    The Softmax function and its derivative
    GNU Screen使用
  • 原文地址:https://www.cnblogs.com/cgmcoding/p/13279406.html
Copyright © 2011-2022 走看看