matplotlib图形绘制(上)

示例一:初始折线图1

# 展示某城市一周的天气变化情况
import matplotlib.pyplot as plt
# 1. 创建画布
plt.figure()
# 2. 绘制图像
plt.plot([1, 2, 3, 4, 5, 6, 7], [17, 15, 18, 16.9, 17, 19, 18])
# 3. 展示图像
plt.show()
output_1_0.png

完善折线图1(画布层-尺寸和像素)

import matplotlib.pyplot as plt
# 1. 创建画布
# 创建画布时可以直接修改图像的属性:大小尺寸,像素(清晰度)
plt.figure(figsize=(15, 8), dpi=60)
# 2. 绘制图像
x = range(1, 8)
y = [17, 15, 18, 16.9, 17, 19, 18]
plt.plot(x, y)
# 保存图像,注意:必须写在展示图像之前,因为展示完图片后会自动释放所有图像资源,如果保存则会保存空图像
plt.savefig("./Matplot-Image/weather1.png")
# 3. 展示图像
plt.show()
output_3_0.png

示例二:初始折线图2

# 展示上海市11点到12点1小时内每分钟温度的变化折线图,假设温度范围在15度~20度之间
# 思路和步骤:
# 1. 准备数据(x表示11点到12点,按照分钟显示;y表示温度的变化情况[15°~20°之间])
import random
import matplotlib.pyplot as plt

x = range(60)
# 每分钟的温度变化,即y轴随着x轴变化而变化,故循环生成60次15~18之间均衡分布的数
y = [random.uniform(15, 20) for i in x]

# 2. 创建画布,指定画布尺寸【figsize】和像素(清晰度)[dpi]
plt.figure(figsize=(20,8),dpi = 60)

# 3. 绘制图像(按照要求进行展示)
plt.plot(x, y)

# 4. 展示图片
plt.show()
output_5_0.png

完善折线图2(辅助显示层-修改x和y轴)

import random
import matplotlib.pyplot as plt

x = range(60)
# 每分钟的温度变化,即y轴随着x轴变化而变化,故循环生成60次0°到40°之间均衡分布的数(某城市温度的范围)
y = [random.uniform(15, 20) for i in x]

# 2. 创建画布
plt.figure(figsize=(20,8),dpi = 90)

# 3. 绘制图像(按照要求进行展示)
plt.plot(x, y)

# 修改x、y的刻度显示
x_label = ["11点{}分".format(i) for i in x]
plt.xticks(x[::5], x_label[::5])


j = range(0, 41)[::5]
y_label = ["{}°".format(i) for i in j]
plt.yticks(range(0, 41)[::5], y_label)

# 显示背景网格(True默认可以省略,表示增加网格,linestyle表示网格线风格,alpha表示透明度)
plt.grid(True, linestyle="--", alpha=0.5)

# 添加描述信息
plt.xlabel("时间/分钟")
plt.ylabel("温度")
plt.title("上海市11点到12点每分钟温度变化情况")

# 4. 展示图片
plt.show()
output_7_0.png

完善折线图2(图像层-添加城市)

# 需求:在原有图像基础上再添加一个城市温度变化
# 展示11点到12点北京的温度变化(假设温度变化范围在1度到3度之间)
# 思路:
# 1. x和y轴不用改变(辅助显示层不动)、在图像层再增加一条折线图即可。
# 2. 在原有折线图基础上准备北京温度数据(图像层进行)
# 具体步骤:
# 1> 创建画布
import random
import matplotlib.pyplot as plt
plt.figure(figsize=(20, 8), dpi=80)
# 2> 绘制图像
# ① 准备数据
x = range(60)
y_shanghai = [random.uniform(15, 20) for i in x]
y_beijing = [random.uniform(1, 3) for i in x]

# ② 绘制图像(可以指定折线风格、颜色等)
plt.plot(x, y_shanghai, color="r", linestyle="-.", label="上海")
plt.plot(x, y_beijing, color="b", linestyle="-", label="北京")

# ③ 修改x和y轴的刻度
x_label = ["11点{}分".format(i) for i in x]
plt.xticks(range(60)[::5], x_label[::5])
j = range(0, 41, 5)
y_label = ["{}°".format(i) for i in j]
plt.yticks(range(41)[::5], y_label)

# ④ 添加网格
plt.grid(linestyle="--", alpha=0.5)

# ⑤ 添加描述信息
plt.xlabel("时间/分钟")
plt.ylabel("温度")
plt.title("上海、北京11点到12点温度变化情况")

# ⑥ 添加图例
#plt.legend()
plt.legend(loc="upper center")

# 3> 展示图像
plt.show()
output_9_0.png

完善折线图2(多个绘图区)

# 1. 创建画布
import random
import matplotlib.pyplot as plt

# 使用subplots(nrows=行数,ncols=列数,...)创建容器层对象(画布和坐标系),返回画布和坐标
figure,axes = plt.subplots(nrows=1, ncols=2, figsize=(20, 8), dpi=60)

# 2. 绘制图像
# ① 准备数据
x = range(0,60)
y_shanghai = [random.uniform(15, 20) for i in x]
y_beijing = [random.uniform(1, 3) for i in x]

# ② 绘制图像(可以指定折线风格、颜色等)
# plt.plot(x, y_shanghai, color="r", linestyle="-.", label="上海")
# plt.plot(x, y_beijing, color="b", linestyle="-", label="北京")
axes[0].plot(x, y_shanghai, color="r", linestyle="-.", label="上海")
axes[1].plot(x, y_beijing, color="b", linestyle="-", label="北京")

# ③ 修改x和y轴的刻度
x_label = ["11点{}分".format(i) for i in x]
axes[0].set_xticks(range(60)[::5])
axes[0].set_xticklabels(x_label[::5])

j = range(0, 41, 5)
y_label = ["{}°".format(i) for i in j]
axes[0].set_yticks(range(41)[::5])
axes[0].set_yticklabels(y_label)

x_label = ["11点{}分".format(i) for i in x]
axes[1].set_xticks(range(60)[::5])
axes[1].set_xticklabels(x_label[::5])


j = range(0, 41, 5)
y_label = ["{}°".format(i) for i in j]
axes[1].set_yticks(range(41)[::5])
axes[1].set_yticklabels(y_label)

# ④ 添加网格
axes[0].grid(linestyle="--", alpha=0.5)
axes[1].grid(linestyle="--", alpha=0.5)

# ⑤ 添加描述信息
axes[0].set_xlabel("时间/分钟")
axes[0].set_ylabel("温度")
axes[0].set_title("上海11点到12点温度变化情况")

axes[1].set_xlabel("时间/分钟")
axes[1].set_ylabel("温度")
axes[1].set_title("北京11点到12点温度变化情况")

# ⑥ 添加图例
#plt.legend()
axes[0].legend(loc="upper center")
axes[1].legend(loc="upper center")

# 3> 展示图像
plt.show()
output_11_0.png

案例:统计某培训机构一、二季度学员的反馈情况

  • 评价内容包括:课程深度、学员吸收、讲师授课水平
import random
import matplotlib.pyplot as plt

# 1. 创建画布
plt.figure(figsize=(20, 8),dpi=70)
# 2. 绘制图像
# 1> 准备数据
x = ["{}月份".format(i) for i in range(1, 7)]

y_depth = [2, 5, 4, 5, 8, 7]
y_absorb = [4, 3, 3, 5, 2, 4]
y_techer = [4, 6, 5, 8, 7, 9]

# 2> 绘制折线图
plt.plot(x,y_depth, label = "课程深度")
plt.plot(x,y_absorb, label = "学员吸收")
plt.plot(x,y_techer, label = "讲师评价")


# ① 修改y轴的刻度——分数(0分-10分)
plt.yticks(range(11))

# ② 增加图例
#plt.legend(loc="upper center")
plt.legend()

# ③ 增加描述信息
plt.title("某培训机构半年学员反馈情况")
plt.xlabel("时间/月份")
plt.ylabel("评价分数(最高10分)")

# ④ 增加网格背景
plt.grid(linestyle="--", alpha=0.5)

# 3. 展现图像
plt.show()
output_13_0.png

扩展:绘制数学函数

import matplotlib.pyplot as plt
import numpy as np
# 0. 准备数据
x = np.linspace(-1, 1, 1000)
y = pow(x, 2)
#y = pow(2, x)
# 1. 创建画布
plt.figure(figsize=(20, 8), dpi=80)
# 2. 绘制图像
plt.plot(x, y)
# 3. 展现图像
plt.show()
output_13_0.png

知识点小结

1、matplotlib三层结构

  • 容器层

    1. 画板层(Canvas)
    2. 画布层(Figure)——>创建画布(指定尺寸和像素[清晰度])
    3. 绘图区/坐标系(Axes)——>绘制图像——>结合辅助显示区使图更丰富
  • 辅助显示层(在绘图区之上)——>修改x和y轴刻度、描述信息、图例等

  • 图像层(在绘图区之上)——>根据数据描绘图像

2、折线图应用场景

  • 展现某事物、某指标随时间的变化情况!
  • 各种数学函数
  1. 展现公司产品(不同区域)每天活跃用户数
  2. 展现某App每天下载量等
  3. 展现产品新功能上线后,用户点击次数随时间的变化
  4. 画各种数学函数图像
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,530评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 86,403评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,120评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,770评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,758评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,649评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,021评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,675评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,931评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,659评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,751评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,410评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,004评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,969评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,042评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,493评论 2 343