折线图与基础绘图功能

折线图与基础绘图功能

学习目标

内附uniformround的使用实例

  • 目标
    • 知道如何解决中文显示问题
    • 知道matplotlib的图结构
    • 应用figure实现创建绘图区域大小
    • 应用plot实现折线图的绘制
    • 应用title,xlabel,ylabel实现标题以及x,y轴名设置
    • 应用xticks,yticks实现axes的刻度设置和标注
    • 应用savefig实现图形的本地保存
    • 应用grid实现显示网格应用axis实现图像形状修改
    • 应用legend实现图形标注信息显示
    • 应用plt.subplots实现多坐标系的创建
    • 知道如何设置多个axes的标题、刻度
    • 知道折线图的应用场景
  • 应用
    • 天气的温度变化显示

一、Parts of a Figure

fig

二、折线图绘制与保存图片

为了更好的去理解所有基础绘图功能,我们通过天气温度变化的绘图来融合所有的基础API使用

1、matplotlib.pyplot模块

matplotlib.pytplot包含了一系列类似于matlab的画图函数。 它的函数作用于当前图形(figure)的当前坐标系(axes)

import matplotlib.pyplot as plt

2、折线图绘制与显示

####展现上海一周的天气,比如从星期一到星期日的天气温度如下

plt.figure(figsize=(10, 10))  #调整显示图片的大小
plt.plot([1, 2, 3, 4, 5, 6 ,7], [17,17,18,15,11,11,13])
plt.show()

在这里插入图片描述

可以看到这样去显示效果并不好,图形的大小等等,所以我们可以通过加入更多的功能。

3、修改图形大小与图片保存

plt.figure(figsize=(), dpi=)
    figsize:指定图的长宽
    dpi:图像的清晰度
    返回fig对象
plt.savefig(path)
plt.figure(figsize=(20, 8), dpi=80)
plt.savefig("test.png")

会将图片保存到当前路径下

三、温度变化显示

需求:画出某城市11点到12点1小时内每分钟的温度变化折线图,温度范围在15度~18度

效果:

在这里插入图片描述

1、构造数据、显示

# 画出温度变化图
# 创建一个figure
plt.figure(figsize=(20, 8), dpi=80)

# 准备x, y坐标的数据
x = range(60)
y_shanghai = [random.uniform(15, 18) for i in x]  # uniform使用在下面

# 画折线图
plt.plot(x, y_shanghai, label="上海")

plt.show()

uniform和round的使用

import random

# uniform的作用是生成一个float数,round是保留几位小数
x = range(3)
y = [random.uniform(15, 18) for i in x]
print(y)        # [17.000127685591426, 16.96295730110159, 16.682715211367796]
for i in y:
    # z = int(i)
    z = round(i,2)      
    print(z)     # 17.0  16.96   16.68

在这里插入图片描述

2、自定义x,y刻度以及中文显示

  • plt.xticks(x, **kwargs)

    x:要显示的刻度值

  • plt.yticks(y, **kwargs)

    y:要显示的刻度值

# 增加以下两行代码
# 构造中文列表的字符串
x_ch = ["11点{}分".format(i) for i in x]
y_ticks = range(40)

# 修改x,y坐标的刻度
# 第一个参数必须是值,第二个参数必须是与第一个参数相对应中文
plt.xticks(x[::5], x_ch[::5])  #后面的步长必须与前面的步长一样
plt.yticks(y_ticks[::5])

在这里插入图片描述

如果没有解决过中文问题的话,会显示这个样子:

在这里插入图片描述

2.1 中文显示问题解决

matplotlib默认不支持中文
下载中文字体(黑体,看准系统版本)

  • 下载 [arial unicode ms](images/arial unicode ms.ttf) 字体到 /home 目录

  • 拷贝字体到 usr/share/fonts 下:

    sudo cp ~/arial\ unicode\ ms.ttf /usr/share/fonts/arial\ unicode\ ms.ttf
    
  • 修改配置文件matplotlibrc 并且在~/.matplotlib/matplotlibrc也进行修改

    在安装的地方找到虚拟环境ai/lib/python3.6/site-packages/matplotlib/mpl-data目录下面,修改下面三项配置

    font.family         : sans-serif        
    
    font.sans-serif     : arial unicode ms, Bitstream Vera Sans, Lucida Grande, Verdana, Geneva, Lucid, Arial, Helvetica, Avant Garde, sans-serif
    
  • 删除matplotlib字体缓存:

    rm -rf ~/matplotlib/fontList.json
    

3、增加标题、x轴y轴描述信息

plt.xlabel("时间")
plt.ylabel("温度")
plt.title("中午11点0分到12点之间的温度变化图示")

在这里插入图片描述

4、再添加一个城市的温度变化

收集到北京当天温度变化情况,温度在1度到3度。怎么去添加另一个在同一坐标系当中的不同图形,其实很简单只需要再次plot即可,但是需要区分线条,如下显示

在这里插入图片描述

# 生成北京的温度
y_beijing = [random.uniform(1, 3) for i in x]

# 画折线图
plt.plot(x, y_shanghai, label="上海")
# 使用plot可以多次画多个折线,设置颜色,折现类型,图例名称
plt.plot(x, y_beijing, color='r', linestyle='--', label="北京")

# 添加图形注释,如果不添加此设置则不会显示图例
plt.legend(loc="best")

我们仔细观察,用到了两个新的地方,一个是对于不同的折线展示效果,一个是添加注释

4.1自定一个图形风格
颜色字符风格字符
r 红色- 实线
g 绿色- - 虚线
b 蓝色-. 点划线
w 白色: 点虚线
c 青色’ ’ 留空、空格
m 洋红
y 黄色
k 黑色
4.2添加注释

作用是增加图例的显示,如果不加此设置,就算在上面设置了图例,也不会在右上角显示

plt.legend(loc="best")

在这里插入图片描述

5、多个坐标系显示-plt.subplots

如果我们想要将上海和北京的天气图显示在同一个图的不同坐标系当中,效果如下:

在这里插入图片描述

可以通过subplots函数实现(旧的版本中有subplot,使用起来不方便),推荐subplots函数

  • matplotlib.pyplot.subplots(nrows=1, ncols=1, **fig_kw)
    创建一个带有多个坐标系的图

    Parameters:	
    
    nrows, ncols : int, optional, default: 1, Number of rows/columns of the subplot grid.
    **fig_kw : All additional keyword arguments are passed to the figure() call.
    
    Returns:	
    fig : 图对象
    ax : 
    	设置标题等方法不同:
    	set_xticks
    	set_yticks
    	set_xlabel
    	set_ylabel
    

关于axes子坐标系的更多方法:参考https://matplotlib.org/api/axes_api.html#matplotlib.axes.Axes

# 画出温度变化图,展现在不同axes里面
# 创建一个figure(参数:几行,几个坐标系,尺寸)
fig, axes = plt.subplots(nrows=1, ncols=2, figsize=(20, 8), dpi=80)

# 准备x, y坐标的数据
x = range(60)
# y的刻度范围
y_ticks = range(40)
y_shanghai = [random.uniform(15, 18) for i in x]

# 生成北京的温度
y_beijing = [random.uniform(1, 3) for i in x]

# 构造中文列表的字符串
x_ch = ["11点{}分".format(i) for i in x]

# 画折线图
axes[0].plot(x, y_shanghai, label="上海")
# 使用plot可以多次画多个折线
axes[1].plot(x, y_beijing, color='r', linestyle='--', label="北京")


# 美化x,y的刻度值
# 第一个参数必须是刻度数字类型,第二个是对应着第一个数字的中文描述
# plt:对于整体处理,axes:对于每个坐标系处理
# 子坐标系中是set_xticks而不是xticks
axes[0].set_xticks(x[::5], x_ch[::5])
axes[0].set_yticks(y_ticks[::5])

axes[1].set_xticks(x[::5], x_ch[::5])
axes[1].set_yticks(y_ticks[::5])

# 增加x,y描述信息和标题信息
# 也是有set的set_xlable
axes[0].set_xlabel("时间")
axes[0].set_ylabel("温度")

axes[1].set_xlabel("时间")
axes[1].set_ylabel("温度")

axes[0].set_title("中午11点0分到12点之间的温度变化图示")
axes[1].set_title("中午11点0分到12点之间的温度变化图示")

axes[0].legend(loc="best")
axes[1].legend(loc="best")

plt.show()

四、折线图的应用场景

  • 呈现公司产品(不同区域)每天活跃用户数
  • 呈现app每天下载数量
  • 呈现产品新功能上线后,用户点击次数随时间的变化

小结

开头的这几个目标应用全都很重要

  • 知道如何解决中文显示问题
  • 知道matplotlib的图结构
  • 应用figure实现创建绘图区域大小
  • 应用plot实现折线图的绘制
  • 应用title,xlabel,ylabel实现标题以及x,y轴名设置
  • 应用xticks,yticks实现axes的刻度设置和标注
  • 应用savefig实现图形的本地保存
  • 应用grid实现显示网格应用axis实现图像形状修改
  • 应用legend实现图形标注信息显示
  • 应用plt.subplots实现多坐标系的创建
  • 知道如何设置多个axes的标题、刻度
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值