当前位置: 首页 > article >正文

Python数据分析-Matplotlib1

一、折线图的绘制

1.数据分析流程

2.运用Matplot绘制折线图

#encoding=utf-8
import random
from matplotlib import pyplot as plt #绘图工具库
from matplotlib import font_manager #解决中文显示问题
from cProfile import label
#设置字体方式
my_font = font_manager.FontProperties(fname=r"c:\windows\fonts\simsun.ttc",size = 14)
#设置图片的宽高figsize,以及分辨度dpi
plt.figure(figsize=(20,8),dpi = 80)

x = range(0,120)#设置坐标x的值
y_1 = [random.randint(20,35) for i in range(0,120)]#设置坐标y的值
y_2 = [random.randint(20,35) for i in range(0,120)]


_x_ticks = ["10点{}分".format(i) for i in x if i < 60]
_x_ticks = ["11点{}分".format(i-60) for i in x if i > 60]
#fontproperties=my_font用于设置显示中文字体,rotation表示顺时针旋转的度数
plt.xticks(x[::5],_x_ticks[::2],rotation=90,fontproperties=my_font)#x轴的刻度表示
plt.xlabel("时间",fontproperties=my_font)#x轴的标签
plt.ylabel("温度 单位(0c)",fontproperties=my_font)#y轴的标签
plt.title("10点到12点每分钟的气温变化情况",fontproperties=my_font)
#绘制网格,alpha:透明度
plt.grid(alpha = 0.4)
#绘图(plot:绘图),color:线条颜色,linestyle:线条风格,linewidth:线条粗细
plt.plot(x,y_1,label="温度1",linestyle=":")
plt.plot(x,y_2,label="温度2",linestyle="-.")
#添加图例,loc默认为右上角
plt.legend(prop=my_font,loc = "upper right")
#显示
plt.show()from matplotlib import font_manager #解决中文显示问题
from cProfile import label
#设置字体方式
my_font = font_manager.FontProperties(fname=r"c:\windows\fonts\simsun.ttc",size = 14)
#设置图片的宽高figsize,以及分辨度dpi
plt.figure(figsize=(20,8),dpi = 80)

x = range(0,120)#设置坐标x的值
y_1 = [random.randint(20,35) for i in range(0,120)]#设置坐标y的值
y_2 = [random.randint(20,35) for i in range(0,120)]


_x_ticks = ["10点{}分".format(i) for i in x if i < 60]
_x_ticks = ["11点{}分".format(i-60) for i in x if i > 60]
#fontproperties=my_font用于设置显示中文字体,rotation表示顺时针旋转的度数
plt.xticks(x[::5],_x_ticks[::2],rotation=90,fontproperties=my_font)#x轴的刻度表示
plt.xlabel("时间",fontproperties=my_font)#x轴的标签
plt.ylabel("温度 单位(0c)",fontproperties=my_font)#y轴的标签
plt.title("10点到12点每分钟的气温变化情况",fontproperties=my_font)
#绘制网格,alpha:透明度
plt.grid(alpha = 0.4)
#绘图(plot:绘图),color:线条颜色,linestyle:线条风格,linewidth:线条粗细
plt.plot(x,y_1,label="温度1",linestyle=":")
plt.plot(x,y_2,label="温度2",linestyle="-.")
#添加图例,loc默认为右上角
plt.legend(prop=my_font,loc = "upper right")
#显示
plt.show()

3.画图结果展示

二、散点图的绘制

1.运用Matplotlib中的scatter绘制离散图

#encoding=utf-8
from matplotlib import pyplot as plt
from matplotlib import font_manager
from matplotlib.font_manager import FontProperties
my_font = font_manager.FontProperties(fname = r"c:\windows\fonts\simsun.ttc",size=14)
x_3 = range(1,32)
x_10 = range(51,82)
y_3 = [11,17,16,11,12,11,12,6,6,7,8,9,12,15,14,17,18,21,16,17,20,14,15,15,15,19,21,22,22,22,23]
y_10 = [26,26,28,19,21,17,16,19,18,20,20,19,22,23,17,20,21,20,22,15,11,15,5,13,17,10,11,13,12,13,6]

#设置图形大小
plt.figure(figsize=(20,8),dpi=80)
#使用scatter方法绘制散点图,和之前的折线图唯一的区别,显示散点图
plt.scatter(x_3,y_3,label="三月份")
plt.scatter(x_10,y_10,label="十月份")
#调整x轴的刻度
_x = list(x_3)+list(x_10)
_xtick_labels = ["3月{}日".format(i) for i in x_3]
_xtick_labels += ["10月{}日".format(i-50) for i in x_10]
plt.xticks(_x[::3],_xtick_labels[::3],rotation = 45, fontproperties = my_font)
#添加图例
plt.legend(prop=my_font,loc="upper right")
#添加描述信息
plt.xlabel("时间",fontproperties = my_font)
plt.ylabel("温度",fontproperties = my_font)
plt.title("标题",fontproperties = my_font)
plt.show()

2.代码运行效果:

三、条形图绘制

1.使用Matplotlib中的bar绘制条形图:

#encoding=utf-8
from matplotlib import pyplot as plt
from matplotlib import font_manager
my_font = font_manager.FontProperties(fname=r"c:\windows\fonts\simsun.ttc",size=14)
x = ["战狼2","速度与激情8","功夫瑜伽","西游伏妖篇","变形金刚5:最后的骑士","摔跤吧!爸爸","加勒比海盗5:死无对证","金刚:骷髅岛","极限特工:终极回归","生化危机6:终章","乘风破浪","神偷奶爸3","智取威虎山","大闹天竺","金刚狼3:殊死一战","蜘蛛侠:英雄归来","悟空传","银河护卫队2","情圣","新木乃伊",]
y = [56.01,26.94,17.53,16.49,15.45,12.96,11.8,11.61,11.28,11.12,10.49,10.3,8.75,7.55,7.32,6.99,6.88,6.86,6.58,6.23]
#设置图形大小
plt.figure(figsize=(20,15),dpi = 80)
#绘制条形图,横向
#plt.bar(range(len(x)),y,width = 0.3)
#绘制条形图,纵向
plt.barh(range(len(x)),y,height = 0.3,color="orange")
#刻度
plt.yticks(range(len(x)),x,fontproperties=my_font)
plt.grid(alpha=0.3)
#保存
plt.savefig("./movie.png")
plt.show()

2.结果显示为:


http://www.kler.cn/a/272707.html

相关文章:

  • 深度学习 Pytorch 张量(Tensor)的创建和常用方法
  • 【转】厚植根基,同启新程!一文回顾 2024 OpenHarmony 社区年度工作会议精彩瞬间
  • 如何将数据库字符集改为中文,让今后所有的数据库都支持中文
  • 【Docker】使用Dev Container进行开发
  • Python GUI Pyside6 实例笔记
  • 【Hugging Face】下载开源大模型步骤
  • IOS面试题object-c 131-135
  • TSINGSEE青犀AI烟火识别等算法打造电瓶车消防安全解决方案
  • Docker进阶:离线安装docker社区版(docker-18.06.3-ce)
  • vite+vue3项目中svg图标组件封装
  • 使用canvas实现图纸标记及回显
  • Requests教程-17-请求代理设置
  • microk8s使用本地私服registry的镜像http协议
  • The service already exists!怎么解决,Windows怎么安装/卸载服务?
  • RabbitMQ学习总结-消息的可靠性
  • java高频面试题-高级篇
  • C# EPPlus导出dataset----Excel3样式
  • pta系列之古风排版
  • [嵌入式AI从0开始到入土]16_ffmpeg_ascend编译安装及性能测试
  • 2024-03-14学习笔记(YoloV9)
  • 比特币,区块链及相关概念简介(二)
  • d3dcompiler_43.dll缺失,5个方法处理d3dcompiler_43.dll文件缺失
  • JavaEE--小Demo
  • 二叉搜索树、B-树、B+树
  • Hadoop大数据应用:HDFS 集群节点缩容
  • Windows系统安装GeoServe结合内网穿透实现公网访问本地位置信息服务