实验要求

通过可视化可以直观看出人口从1996年到2015年的变化情况,分析我国人口结构变化情况以及变化速率的增减状况。

正文

在数据分析实验中,要求使用matplotlib库,分析作图,可视化数据来帮助我们分析人口变化情况。

首先查看了所给数据后,因为要分析人口结构,首先想到得是男女人口变化情况和城乡人口变化情况,为了更好得看出不同群体得人口数量变化和结构变化,在统计显示人口时,使用直方图同时绘制男性人口数量和女性人口数量。如下:

想要直观看出比例的,用饼状图是一个不错的选择

主要用到的函数:

  1. 直方图
plt.bar(range(2), values[19, 2:4], width=0.5, color='red')
#原函数定义
bar(x, height, width=0.8, bottom=None, ***, align='center', data=None, **kwargs)
  • x: x坐标
  • height:条形的高度
  • width:宽度
  • color:颜色
  1. 饼状图
plt.pie(values[19, 2:4], explode=ex, labels=label1, colors=['pink', 'crimson'], autopct='%1.1f%%')
plt.title('1996年男、女人口数饼图')
  • x:每一块饼图的比例,为必填项,如果sum(x)>1,会将多出的部分进行均分(也就是对应的value 数据部分)
  • labels : 每一块饼图外侧显示的说明文字
  • explode : 每一块饼图 离开中心距离,默认值为(0,0),就是不离开中心
  • colors:数组,可选参数,默认为:None;用来标注每块饼图的matplotlib颜色参数序列。如果为None,将使用当前活动环的颜色。
  1. 箱线图
plt.boxplot(values[0:20, 1:6], notch=True, labels=['年末', '男性', '女性', '城镇', '乡村'], meanline=True)
  • x, 指定要绘制箱线图的数据;
  • meanline=None, # 是否用线的形式表示均值,默认用点来表示;
  • labels=None, # 为箱线图添加标签,类似于图例的作用;
  • notch=None, # 是否是凹口的形式展现箱线图,默认非凹口;

完整代码如下:

import matplotlib
import numpy as np
import matplotlib.pyplot as pltmatplotlib.rcParams['font.sans-serif'] = ['SimHei']
data_load = np.load('data/exp1/populations.npz', allow_pickle=True)
feature = data_load["feature_names"]
values = data_load["data"]plt.rcParams['font.sans-serif'] = 'SimHei'  # 设置中文显示
label1 = ['男性', '女性']  # 标签
label2 = ['城镇', '乡村']
ex = [0.01, 0.01]  # 饼图:设定各项距离圆心n个半径# 1.直方图
p1 = plt.figure(figsize=(24, 8))  # 设置画布大小
# 子图1
a1 = p1.add_subplot(1, 3, 1)
plt.bar(range(2), values[19, 2:4], width=0.5, color='red')
plt.ylabel('人口(万人)')
plt.ylim(0, 80000)  # 设置当前图形y轴的范围
plt.xticks(range(2), label1)  # 指定x轴刻度的数目与取值
plt.title('1996年男、女人口数直方图')# 子图2
b1 = p1.add_subplot(1, 3, 2)
plt.bar(range(2), values[9, 2:4], width=0.5, color='orange')
plt.ylabel('人口(万人)')
plt.ylim(0, 80000)
plt.xticks(range(2), label1)
plt.title('2005年男、女人口数直方图')
# 子图3
c1 = p1.add_subplot(1, 3, 3)
plt.bar(range(2), values[0, 2:4], width=0.5, color='red')
plt.ylabel('人口(万人)')
plt.ylim(0, 80000)
plt.xticks(range(2), label1)
plt.title('2015年男、女人口数直方图')
plt.savefig('1996、2005、2015男女人口数直方图')
# 子图1
p11 = plt.figure(figsize=(24, 8))  # 设置画布大小
d1 = p11.add_subplot(1, 3, 1)
plt.bar(range(2), values[19, 4:6], width=0.5, color='orange')
plt.xlabel('类别')
plt.ylabel('人口(万人)')
plt.ylim(0, 90000)
plt.xticks(range(2), label2)
plt.title('1996年城、乡人口数直方图')# 子图2
e1 = p11.add_subplot(1, 3, 2)
plt.bar(range(2), values[9, 4:6], width=0.5, color='red')
plt.xlabel('类别')
plt.ylabel('人口(万人)')
plt.ylim(0, 90000)
plt.xticks(range(2), label2)
plt.title('2005年城、乡人口数直方图')# 子图3
f1 = p11.add_subplot(1, 3, 3)
plt.bar(range(2), values[0, 4:6], width=0.5, color='orange')
plt.xlabel('类别')
plt.ylabel('人口(万人)')
plt.ylim(0, 90000)
plt.xticks(range(2), label2)
plt.title('2015年城、乡人口数直方图')
plt.savefig('1996、2005、2015年城乡人口直方图.png')  # 保存图片# 2.饼图
p2 = plt.figure(figsize=(12, 8))
# 子图1
a2 = p2.add_subplot(2, 3, 1)
plt.pie(values[19, 2:4], explode=ex, labels=label1, colors=['pink', 'crimson'], autopct='%1.1f%%')
plt.title('1996年男、女人口数饼图')# 子图2
b2 = p2.add_subplot(2, 3, 2)
plt.pie(values[9, 2:4], explode=ex, labels=label1, colors=['PeachPuff', 'skyblue'], autopct='%1.1f%%')
plt.title('2005年男、女人口数饼图')
# 子图3
c2 = p2.add_subplot(2, 3, 3)
plt.pie(values[0, 2:4], explode=ex, labels=label1, colors=['PeachPuff', 'skyblue'], autopct='%1.1f%%')
plt.title('2015年男、女人口数饼图')# 子图4
d2 = p2.add_subplot(2, 3, 4)
plt.pie(values[19, 4:6], explode=ex, labels=label2, colors=['pink', 'crimson'], autopct='%1.1f%%')
plt.title('1996年城、乡人口数饼图')# 子图5
e2 = p2.add_subplot(2, 3, 5)
plt.pie(values[9, 4:6], explode=ex, labels=label2, colors=['PeachPuff', 'skyblue'], autopct='%1.1f%%')
plt.title('2005年城、乡人口数饼图')# 子图6
f2 = p2.add_subplot(2, 3, 6)
plt.pie(values[0, 4:6], explode=ex, labels=label2, colors=['PeachPuff', 'skyblue'], autopct='%1.1f%%')
plt.title('2015年城、乡人口数饼图')
plt.savefig('1996、2005、2015年各类人口饼图.png')# 3.箱线图
p3 = plt.figure(figsize=(10, 10))
plt.boxplot(values[0:20, 1:6], notch=True, labels=['年末', '男性', '女性', '城镇', '乡村'], meanline=True)
plt.xlabel('类别')
plt.ylabel('人口(万人)')
plt.title('1996~2015年各特征人口箱线图')
plt.savefig('1996`2015年各特征人口箱线图.png')# 显示
plt.show()

数据分析——人口变化matplotilb绘图相关推荐

  1. 汉字编码变化_新编码员:薪资和时间花费如何根据人口变化

    汉字编码变化 by David Venturi 大卫·文图里(David Venturi) 新编码员:薪资和时间花费如何根据人口变化 (New Coders: How Salary and Time ...

  2. [数据分析与可视化] 数据绘图要点9-颜色的选择

    数据绘图要点9-颜色的选择 文章目录 数据绘图要点9-颜色的选择 颜色绘图要点 准确选择图表类型 如何做出更好的颜色选择 绘图实例 参考 颜色是数据可视化中传达信息的主要媒介之一.它们允许我们适当突出 ...

  3. matplotlib柱状图上方显示数据_Python数据分析matplotlib可视化之绘图!

    Matplotlib是一个基于python的2D画图库,能够用python脚本方便的画出折线图,直方图,功率谱图,散点图等常用图表,而且语法简单. Python中通过matplotlib模块的pypl ...

  4. python可视化直方图的x轴参数设置_Python数据分析matplotlib可视化之绘图

    Matplotlib是一个基于python的2D画图库,能够用python脚本方便的画出折线图,直方图,功率谱图,散点图等常用图表,而且语法简单. Python中通过matplotlib模块的pypl ...

  5. [数据分析与可视化] 数据绘图要点11-雷达图的注意事项

    数据绘图要点11-雷达图的注意事项 准确通过雷达图表现数据有许多值得需要思考的地方,本文主要介绍雷达图的一些注意事项. 文章目录 数据绘图要点11-雷达图的注意事项 雷达图绘制 基础雷达图 多类别雷达 ...

  6. [数据分析与可视化] 数据绘图要点1-注重数据排序

    数据绘图要点1-注重数据排序 文章目录 数据绘图要点1-注重数据排序 实例 无序棒棒糖图 有序棒棒糖图 参考 默认情况下,大多数数据可视化工具将使用字母顺序或使用输入表中的出现顺序对分类变量组进行排序 ...

  7. python画中国人口变化情况以及数据拟合

    数据来源中国人口统计年鉴 mport matplotlib.pyplot as plt import numpy as np import xlrd from scipy.optimize impor ...

  8. 2020、2021近两年全球人口变化数据集

    1950-2020年,全球人口从25.4亿人增长至77.9亿人,年复合增长率为1.61%.到2100年,世界人口依然会处于增长阶段,但人口增长率出现放缓态势. 联合国预测:2022年11月15日左右, ...

  9. [数据分析与可视化] ​数据绘图要点5-误差线的问题

    数据绘图要点5-误差线的问题 文章目录 数据绘图要点5-误差线的问题 误差线的绘制 误差线中的问题 误差线隐藏信息 误差线的计算方式 解决方法 参考 误差线给出了测量精确度的一般概念,真实(无误差)值 ...

  10. [数据分析与可视化] 数据绘图要点6-数据组过多

    数据绘图要点6-数据组过多 比较几个数值变量的分布是数据展示中的一项常见任务.变量的分布可以使用直方图或密度图来表示,在同一轴上表示适量数据的组是非常有吸引力的.但是数据组过多将严重影响图表信息表现. ...

最新文章

  1. 如何将Android带入互联网数字家庭? 第一篇转载
  2. java ror框架搭建_ROR 环境的 搭建
  3. 【数理知识】辛矩阵 symplectic
  4. 最新android版本奥利奥,最新Android 8.1即将来临,你想吃奥利奥了吗?
  5. python相关软件安装
  6. 哪一个不是linux常用的shell,Linux下查看使用的是哪种shell的方法汇总
  7. 大数据|意不意外?今年卖得最好的月饼是这个馅的……
  8. Redis:22---客户端API:client、monitor)
  9. 创建型、结构型、行为型模式(1)
  10. 安装wordpress之激活mod_rewrite
  11. python对excel数据更改_利用python对excel中一列的时间数据更改格式代码示例
  12. 过程中存根的作用有_聚氨酯发泡胶有哪些作用?使用过程中表现出哪些特点?...
  13. AndroidStudio_在android中使用定时器_异步定时实现心跳保活功能---Android原生开发工作笔记231
  14. 如何在SQL Server中自动进行表分区
  15. Vue学习笔记(六) 表单输入绑定
  16. 《中国人工智能学会通讯》——7.7 结束语
  17. FastDFS存储服务器部署
  18. excanvas让canvas兼容ie7,8
  19. [转载] python 语言基础 - 字符串常用函数及操作
  20. MySQL 5.7安装(多实例)最佳实践

热门文章

  1. 【Linux上分之路】第二篇:Linux硬件、磁盘结构和分区,Linux文件目录结构
  2. 计算机应用期刊查重率要求,计算机学报先审稿还是先查重
  3. wine qq2011beta4
  4. 太阳系行星运行图-java多媒体实验
  5. 前端面试必备知识点总结(持续更新)
  6. 向《基础微积分》教科书翻译者致敬
  7. python递归排列组合_Python 排列组合
  8. ICPC冠军教练亲自授课 字节跳动ICPC冬令营全球招募50支受训队
  9. Z820安装Win7系统出现0X0000007B蓝屏报错无限重启的解决方法与相关问题
  10. K8S学习之容器探测 livenessProbe、readinessProbe、startupProbe、lifecycle