Python数据分析笔记_第2天(matplotlib_散点图+条形图)_python绘制北京3,10月白天最高气温变化散点图-程序员宅基地

技术标签: python  学习笔记--python数据分析  

常用统计图

  • 折线图:显示数据的变化趋势,反映事物的变化情况(变化)
  • 直方图:绘制连续性的数据,展示一组或者多组数据的分布状况(统计)
  • 条形图:绘制连离散的数据,能一眼看出各个数据的大小,比较数据之间的差别(统计)
  • 散点图:判断横纵轴之间是否存在数量关联趋势,展示离群点(分布规律)

matplotlib散点图

  • plt.scatter(x, y, label=‘图例’)绘制散点图,plt.legend(loc=‘upper left’)显示图例

北京2016年3,10月份白天的最高气温(分别位为x_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],x_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]),那么此时如何寻找出气温和随时间(天)变化的某种规律?

from matplotlib import pyplot as plt
import matplotlib

# 设置中文格式
font = {
    'family': 'Microsoft YaHei',
        'size': '12'}
matplotlib.rc('font', **font)

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]
x_3 = range(1, 32)
x_10 = range(51, 82)

# 设置图像大小
plt.figure(figsize=(15, 4), dpi=80)

# 调整x轴的刻度
_x_3 = list(x_3)
_x_10 = list(x_10)
_x = _x_3 + _x_10  # 将两段x取值合并成一个列表
x_label_3 = ['3月{}日'.format(i) for i in x_3]
x_label_10 = ['10月{}日'.format(i - 50) for i in x_10]
x_label = x_label_3 + x_label_10  # 数字所对应的字符串也合并成一个列表
plt.xticks(_x[::3], x_label[::3], rotation=45)

# 添加描述信息
plt.xlabel('日期')
plt.ylabel('温度')
plt.title('北京2016年3、10月白天最高气温')

#  plt.scatter(x,y)绘制散点图
plt.scatter(x_3, y_3, label='3月份',color='blue')  # label设置图例参数
plt.scatter(x_10, y_10, label='10月份',color='red')  # 当两组数据绘制在一张图上时调整x的取值范围

# 添加图例
plt.legend(loc='upper left')  # loc设置图例显示位置
plt.grid(alpha=0.3,linestyle='--')  # 显示网格线,透明度为0.3的虚线
plt.show()

matplotlib条形图

  • plt.bar(x, y, width=‘宽度’)绘制柱状图;plt.barh(x, y,height=‘高度’)绘制条形图

已有2017年内地电影票房前20的电影(列表a)和电影票房数据(列表b),直观的展示该数据。
a = [“战狼2”,“速度与激情8”,“功夫瑜伽”,“西游伏妖篇”,“变形金刚5:最后的骑士”,“摔跤吧!爸爸”,“加勒比海盗5:死无对证”,“金刚:骷髅岛”,“极限特工:终极回归”,“生化危机6:终章”,“乘风破浪”,“神偷奶爸3”,“智取威虎山”,“大闹天竺”,“金刚狼3:殊死一战”,“蜘蛛侠:英雄归来”,“悟空传”,“银河护卫队2”,“情圣”,“新木乃伊”,]
b=[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] 单位:亿

from matplotlib import pyplot as plt
import matplotlib


# 文字设置
font = {
    'family': 'Microsoft YaHei',
        'size': '12'}
matplotlib.rc('font', **font)

# 大小设置
plt.figure(figsize=(20, 5), dpi=80)

# 数据准备
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.xticks(range(int(min(y) - 1), int(max(y) + 1), 2))
plt.ylabel('电影名')
plt.xlabel('电影票房(单位:亿)')
plt.title('2017年内地电影前20票房')

# 作图
plt.barh(x, y, height=0.5)  # plt.bar绘制柱状图,plt.barh绘制条形图
plt.grid(alpha=0.3, linestyle='--')
plt.show()

假设你知道了列表a中电影分别在2017-09-14(b_14), 2017-09-15(b_15), 2017-09-16(b_16)三天的票房,为了展示列表中电影本身的票房以及同其他电影的数据对比情况,应该如何更加直观的呈现该数据?
a = [“猩球崛起3:终极之战”,“敦刻尔克”,“蜘蛛侠:英雄归来”,“战狼2”]
b_16 = [15746,312,4497,319]
b_15 = [12357,156,2045,168]
b_14 = [2358,399,2358,362]

'''
当多组数据绘制在同一张图时,注意数据组在横坐标上的平移避免图形重叠
'''
from matplotlib import pyplot as plt
import matplotlib

# 文字设置
font = {
    'family': 'Microsoft YaHei',
        'size': '12'}
matplotlib.rc('font', **font)

# 图片大小
plt.figure(figsize=(15, 5), dpi=80)

# 数据准备
a = ["猩球崛起3:终极之战", "敦刻尔克", "蜘蛛侠:英雄归来", "战狼2"]
y_14 = [2358, 399, 2358, 362]
y_15 = [12357, 156, 2045, 168]
y_16 = [15746, 312, 4497, 319]
y = y_14 + y_15 + y_16

# x轴平移,避免图表重合
move = 0.2  # 设置平移距离
x_14 = list(range(len(a)))  # 先用数字占位,后再对应字符串
x_15 = [i + move for i in x_14]
x_16 = [i + move * 2 for i in x_14]
x_label = x_14 + x_15 + x_16

# 设置坐标轴显示刻度
plt.xticks(x_15, a)

# 作图
plt.bar(x_14, y_14, width=move, color= 'r',label='9月14日')
plt.bar(x_15, y_15, width=move, color='b', label='9月15日')
plt.bar(x_16, y_16, width=move, color='orange', label='9月15日')
plt.grid(alpha=0.3, linestyle='--')
plt.legend(loc='upper right')
plt.show()
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_44454872/article/details/114196496

智能推荐

VDSR论文学习笔记-程序员宅基地

文章浏览阅读1.4k次,点赞2次,收藏11次。VDSR网络是韩国首尔国立大学Jiwon Kim等人在SRCNN基础上又一次新的突破,在单图像超分辨率重建(SR)方面展示出了更好的性能。_vdsr

dotnet serve, 一行命令开启本地 web 服务-程序员宅基地

文章浏览阅读15次。dotnet-servedotnet-serve 是一个基于 .NET Core CLI 的简单命令行工具,100% 使用 C# 开发,它可以使用一行命令,开启本地 web 服务,类似于前端的 http-serve 工具,开箱即用,本地开发或者调试都非常。如果您是 dotnet 开发人员,这会很方便,因为它只是向默认的 dotnet cli 命令添加了另一个工具。如何使用?使用 dotnet to...

maskrcnn-pytorch-gpu训练时遇到的问题_maskcn使用gpu版本的pytorch-程序员宅基地

文章浏览阅读473次。2021.7.30训练环境:Python 3.6.5CUDA 10.0Pytorch 1.2.0Cudnn 7.6..2Torchvision 0.4Cudatoolkit 10.0.130Ubutun16.04.6GCC 5.4.0Maskrcnn训练进程:新建虚拟环境Conda create -n maskrcnn2 python=3.6.5安装合适的pip以及依赖condainstallipythonpip安装cocoapipi..._maskcn使用gpu版本的pytorch

第一届BCNSCTF Write Up_igyw-程序员宅基地

文章浏览阅读1.5k次。前言:这是第一届BCNSCTF Write Up,觉得其中的CRYPTO有点东西。CRYPTOthree days of lighthint:1.吉奥万巴蒂斯塔贝拉索先生的密码打开文件⡹⡷⡩⡧⡋⠁⡗⡯⠁⠅⡯⡊⡨⡄⡠⡩⡯⡜⠄⠅⡓⡯⡳⡝⠉⡅⡑⡯⡢⠀⡘⡯⡍=虽然和盲文有点区别,但还是丢去在线解密试一试,得到IGYW{1g_15_zXtPY_l45c_Cm9ua_R0h_}有flag的格式..._igyw

python xlwt写入一行_python xlwt模块写入excel超过65536行报错问题解决方法-程序员宅基地

文章浏览阅读881次。上篇文章中将内容写到excel中使用import xlwt包,后来发现文件写入超过65536行的时候就会报错,无法转换成功,xls后缀文件,只支持这么多行,在网上搜索一下,解决方法可以写多个sheet页,但不是我想要的方式,后来后搜索了下,找到了openpyxl包,使用这个包写入数据,文件保存为xlsx格式的,就可以完美解决。1、安装包pip install openpyxl2、再将上篇文章代码(..._python的xlwt不能正确写入以及缓冲区问题 3700行数据

tensorflow/models模块的介绍与安装-程序员宅基地

文章浏览阅读3.4k次。简介先给出GitHub地址https://github.com/tensorflow/models, 再看官方的简介简单来讲,这里面包含了很多封装好了的模型可供使用,极大的提升了研究效率。目录GitHub的目录结构如下,常用的轮子在research目录之下进入research会发现很多目录,是各领域的研究员封装的非常好用的轮子。下面有着每个目录的介绍网上博客对object_d..._tensorflow/models

随便推点

2.xilinx sdk使用教程_xilinx sdk怎么生成elf-程序员宅基地

文章浏览阅读7.6k次。本文参考 Xilinx SDK软件内置的教程,打开方法:打开SDK->Help->Cheet Sheets...->Xilinx SDK Tutorials,这里有6篇文档。本文详细介绍其中的4篇(与Application相关)如何创建一个新的软件应用1.打开SDK,切换到c/c++界面下。(有两个界面,还有一个是Debug界面,在软件右上角处切换)2.指定一个_xilinx sdk怎么生成elf

linux内核链接脚本详解-程序员宅基地

文章浏览阅读1.2w次,点赞5次,收藏39次。1. 什么是链接脚本链接器主要有两个作用,一是将若干输入文件(.o文件)根据一定规则合并为一个输出文件(例如ELF格式的可执行文件);一是将符号与地址绑定(当然加载器也要完成这一部分工作)。关于链接器的工作机制可以参考《Linker and Loader》一书,本文只关心它的第一个功能,即如何根据一定规则将一个或多个输入文件合并成输出文件。这里的“一定规则”是通过链接脚本描述的。链接器有一个编

[图解]DDD领域驱动设计伪创新-通用语言06-程序员宅基地

文章浏览阅读628次,点赞6次,收藏20次。所有的领域,难度都是一样的

ISP 处理流程_isp流程-程序员宅基地

文章浏览阅读910次。(另一种奇怪的解释:实际AD芯片(模数转换芯片)的精度可能无法将电压值很小的一部分转换出来,因此,sensor厂家一般会在AD的输入之前加上一个固定的偏移量,使输出的pixel value在n(每家不同)~255之间,目的是为了让暗部的细节完全保留,当然加了之后高光信号溢出,会损失一些亮部细节。-----------------------------------------一个发散问题 start ------------------------------------------------_isp流程

[附源码]计算机毕业设计Python财务管理系统(程序+源码+LW文档)_python记账系统 源代码-程序员宅基地

文章浏览阅读685次。该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程项目运行环境配置:Pychram社区版+py项目技术:django + python+ Vue 等等组成,B/S模式 +pychram管理等等。环境需要1.运行环境:最好是python3.7.7,我们在这个版本上开发的。其他版本理论上也可以。2.pycharm环境:pycharm都可以。推荐pycharm社区版;3.mysql环境:建议是用5.7版本均可。_python记账系统 源代码

[附源码]JSP+ssm计算机毕业设计新冠疫苗接种管理系统设计与实现zbb8o【源码、数据库、LW、部署】-程序员宅基地

文章浏览阅读95次。Jdk1.8 + Tomcat7.0 + Mysql + HBuilderX(Webstorm也行)+ Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。2. 前端:L ayui+css+javascript+jQuery+ElemenUI+highcharts。SSM + mybatis + Maven + JSP 等等组成,B/S模式 + Maven管理等等。2. 使用IDEA/Eclipse/MyEclipse导入项目,修改配置,运行项目;

推荐文章

热门文章

相关标签