python分析人口出生率代码_国家统计局居然也能用的上Python?人口数据Python脚本了解一下?…[通俗易懂]

python分析人口出生率代码_国家统计局居然也能用的上Python?人口数据Python脚本了解一下?…[通俗易懂]原标题:国家统计局居然也能用的上Python?人口数据Python脚本了解一下?通过采集国家统计局“国家数据”网站中提供的中国历年人口数据,并对数据进行可视化的探索,发现了一些有意思和令人深思的现象和趋势。有一些小伙伴后台留言希望公布一下采集“国家数据”网站人口数据的代码,在这里,就将总人口、人口出生率、人口年龄结构和人口平均寿命4项数据的代码公布出来,方便大家学习和使用。文章目录涉及到的模块在这…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

原标题:国家统计局居然也能用的上Python?人口数据Python脚本了解一下?

通过采集国家统计局“国家数据”网站中提供的中国历年人口数据,并对数据进行可视化的探索,发现了一些有意思和令人深思的现象和趋势。

有一些小伙伴后台留言希望公布一下采集“国家数据”网站人口数据的代码,在这里,就将总人口、人口出生率、人口年龄结构和人口平均寿命4项数据的代码公布出来,方便大家学习和使用。

文章目录

涉及到的模块

在这里使用到的第三方库有requests,通过pip命令即可直接安装:

pip install requests

使用到的内置库有:

json:用于解析接口返回的数据;

csv:用于将数据写入到CSV文件中;

同时使用到的header请求头为:

headers = {

‘Host’: ‘data.stats.gov.cn’,

‘Connection’: ‘keep-alive’,

‘Accept’: ‘application/json, text/java, */*; q=0.01’,

‘X-Requested-With’: ”,

‘User-Agent’: ‘Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/63.0.3239.132 Safari/537.36’,

‘Referer’: ‘http://data.stats.gov.cn/easyquery.htm?cn=C01’,

‘Accept-Encoding’: ‘gzip, deflate’,

‘Accept-Language’: ‘zh-CN,zh;q=0.9’,

}

生成年份列表

# 获取年份列表

def get_year_list():

year_list = []

for i in range(1949,2017):

year_list.append(str(i))

return year_list

总人口

总人口数据中包含年份、总人口、男性人口、女性人口、城镇人口、乡村人口5项,保存为总人口.csv文件:

# 总人口

def get_total_population():

year_list = get_year_list()

with open(‘总人口.csv’, ‘a+’, encoding=’utf-8′, newline=”) as files:

fieldnames = [‘年份’, ‘年末总人口(万人)’, ‘男性人口(万人)’, ‘女性人口(万人)’, ‘城镇人口(万人)’, ‘乡村人口(万人)’]

writer = csv.DictWriter(files, fieldnames=fieldnames)

writer.writeheader()

for year in year_list:

url = ‘http://data.stats.gov.cn/easyquery.htm?m=QueryData&dbcode=hgnd&rowcode=zb&colcode=sj&wds=%5B%5D&dfwds=%5B%7B%22wdcode%22%3A%22sj%22%2C%22valuecode%22%3A%22{year}%22%7D%5D’.format(

year=year)

wbdata = requests.get(url, headers=headers)

jsdata = json.loads(wbdata.text)

data = jsdata[‘returndata’][‘datanodes’]

item = {

‘年份’: year + ‘年’,

‘年末总人口(万人)’: data[0][‘data’][‘data’], # 年末总人口(万人)

‘男性人口(万人)’: data[1][‘data’][‘data’], # 男性人口(万人)

‘女性人口(万人)’: data[2][‘data’][‘data’], # 女性人口(万人)

‘城镇人口(万人)’: data[3][‘data’][‘data’], # 城镇人口(万人)

‘乡村人口(万人)’: data[4][‘data’][‘data’], # 乡村人口(万人)

}

print(item)

writer.writerow(item)

人口出生率、死亡率和自然增长率

包含年份、出生率、死亡率、自然增长率4项数据,数据保存为出生死亡及自然增长率.csv文件:

# 人口出生率、死亡率和自然增长率

def get_birth_death_rate():

year_list = get_year_list()

with open(‘出生死亡及自然增长率.csv’,’a+’,encoding=’utf-8′,newline=”) as files:

fieldnames = [‘年份’, ‘出生率’, ‘死亡率’, ‘自然增长率’]

writer = csv.DictWriter(files, fieldnames=fieldnames)

writer.writeheader()

for year in year_list:

url = ‘http://data.stats.gov.cn/easyquery.htm?m=QueryData&dbcode=hgnd&rowcode=zb&colcode=sj&wds=%5B%5D&dfwds=%5B%7B%22wdcode%22%3A%22sj%22%2C%22valuecode%22%3A%22{year}%22%7D%5D’.format(year=year)

wbdata = requests.get(url,headers=headers)

jsdata = json.loads(wbdata.text)

data = jsdata[‘returndata’][‘datanodes’]

item = {

‘年份’ : year+’年’,

‘出生率’ : data[0][‘data’][‘data’], # 人口出生率

‘死亡率’ : data[1][‘data’][‘data’], # 人口死亡率

‘自然增长率’ : data[2][‘data’][‘data’], # 人口自然增长率

}

print(item)

writer.writerow(item)

人口年龄结构及抚养比

包含年份、年末总人口、0-14岁人口、15-64岁人口、65岁及以上人口、总抚养比、少儿抚养比、老年抚养比8项数据,数据保存为人口年龄结构及抚养比.csv文件:

def get_age_structure():

year_list = get_year_list()

with open(‘人口年龄结构及抚养比.csv’, ‘a+’, encoding=’utf-8′, newline=”) as files:

fieldnames = [‘年份’, ‘年末总人口(万人)’, ‘0-14岁人口(万人)’, ’15-64岁人口(万人)’, ’65岁及以上人口(万人)’, ‘总抚养比(%)’, ‘少儿抚养比(%)’, ‘老年抚养比(%)’]

writer = csv.DictWriter(files, fieldnames=fieldnames)

writer.writeheader()

for year in year_list:

url = ‘http://data.stats.gov.cn/easyquery.htm?m=QueryData&dbcode=hgnd&rowcode=zb&colcode=sj&wds=%5B%5D&dfwds=%5B%7B%22wdcode%22%3A%22sj%22%2C%22valuecode%22%3A%22{year}%22%7D%5D’.format(

year=year)

wbdata = requests.get(url, headers=headers)

jsdata = json.loads(wbdata.text)

data = jsdata[‘returndata’][‘datanodes’]

item = {

‘年份’: year + ‘年’,

‘年末总人口(万人)’: data[0][‘data’][‘data’], # 年末总人口(万人)

‘0-14岁人口(万人)’: data[1][‘data’][‘data’], # 0-14岁人口(万人)

’15-64岁人口(万人)’: data[2][‘data’][‘data’], # 15-64岁人口(万人)

’65岁及以上人口(万人)’: data[3][‘data’][‘data’], # 65岁及以上人口(万人)

‘总抚养比(%)’: data[4][‘data’][‘data’], # 总抚养比(%)

‘少儿抚养比(%)’: data[5][‘data’][‘data’], # 少儿抚养比(%)

‘老年抚养比(%)’: data[6][‘data’][‘data’], # 老年抚养比(%)

}

print(item)

writer.writerow(item)

人口平均预期寿命

包含年份、平均预期寿命、男性平均预期寿命、女性平均预期寿命4项数据,数据保存为人口平均预期寿命.csv文件:

def get_avg_life():

year_list = get_year_list()

with open(‘人口平均预期寿命.csv’, ‘a+’, encoding=’utf-8′, newline=”) as files:

fieldnames = [‘年份’, ‘平均预期寿命(岁)’, ‘男性平均预期寿命(岁)’, ‘女性平均预期寿命(岁)’]

writer = csv.DictWriter(files, fieldnames=fieldnames)

writer.writeheader()

for year in year_list:

url = ‘http://data.stats.gov.cn/easyquery.htm?m=QueryData&dbcode=hgnd&rowcode=zb&colcode=sj&wds=%5B%5D&dfwds=%5B%7B%22wdcode%22%3A%22sj%22%2C%22valuecode%22%3A%22{year}%22%7D%5D’.format(

year=year)

wbdata = requests.get(url, headers=headers)

jsdata = json.loads(wbdata.text)

data = jsdata[‘returndata’][‘datanodes’]

item = {

‘年份’: year + ‘年’,

‘平均预期寿命(岁)’: data[0][‘data’][‘data’], # 男性平均预期寿命(岁)

‘男性平均预期寿命(岁)’: data[1][‘data’][‘data’], # 人口死亡率

‘女性平均预期寿命(岁)’: data[2][‘data’][‘data’], # 人口自然增长率

}

print(item)

writer.writerow(item)

打包

加我微信:Python654472766 人口统计即可获取源码哦!

责任编辑:

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/197638.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • MySQL 1045登录失败

    MySQL 1045登录失败当你登录MySQL数据库出现:Error1045错误时(如下图),就表明你输入的用户名或密码错误被拒绝访问了,最简单的解决方法就是将MySQL数据库卸载然后重装,但这样的缺点就是就以前的数据库中的信息将丢失,如果你不想重装,那么就需要找回密码或者重置密码。解决的方法应该有多种,这里我推荐大家使用一种原理通过,操作简单的方法,适用于windows以及linux平台。 MySQL1045错误如

  • 浅析Nginx与Apache的区别[通俗易懂]

    浅析Nginx与Apache的区别[通俗易懂]Nginx:1.轻量级,采用C进行编写,同样的web服务,会占用更少的内存及资源2.抗并发,nginx以epollandkqueue作为开发模型,处理请求是异步非阻塞的,多个连接对应一个进程,负载能力比apache高很多,而apache则是同步多进程模型,只能一个连接对应一个进程,当压力过大时,它是会被阻塞型的。在高并发下nginx能保持低资源低消耗高性能,而apache在PHP处…

  • 使用clion创建c项目_C语言模板

    使用clion创建c项目_C语言模板参考链接File->Setting->Editor->FileandCodeTemplates选择Files选项卡,选择要要添加模板代码的文件类型在输入框中写入模板代码(关于作者,时间什么的,参考链接有说)要注意的是,#开头的代码,要用#[[…]]包起来…

  • 十字路口的交通灯控制系统_十字路口红绿灯控制程序设计

    十字路口的交通灯控制系统_十字路口红绿灯控制程序设计十字路口交通信号灯控制系统主要任务开发平台设计思路主要任务设计一个用于十字路口的交通灯控制器,能显示十字路口东西、南北两个方向的红、黄、绿的指示状态;具有倒计时的功能,用两组数码管作为东西和南北方向的倒计时显示,**主干道直行(绿灯)60秒后,左转(绿灯)40秒;支干道直行(绿灯)45秒后,左转(绿灯)30秒,**在每次绿灯变成红灯的转换过程中,要亮黄灯5秒作为过渡。黄灯每秒闪亮一次。只考虑直行和左转车辆控制信号灯,右转车辆不受信号灯控制,南北向车辆与东西向车辆交替方向,同方向等待车辆应先方向直

  • Lena图像分解成小块与从小块合成

    Lena图像分解成小块与从小块合成 ➤01背景在2020年人工神经网络课程第一次作业第八题中需要对Lena图像使用AutoEncode网络进行压缩。将Lena(灰度图像)拆解成不同尺寸的大小形成训练压缩样本过程;或者从训练结果重新组合成Lena灰度图像是实验的基础。▲Lena灰度图像下面给出相关操作的Python程序和相关的结果。主要操作包括:将512×512的Lena灰度图片(0~255)分割成边长8~16的图像块,并通过行扫描形行向量;对图像进行归一化,形成数据在-0.5~0.5之

  • pychram2021.12激活【2021.10最新】

    (pychram2021.12激活)这是一篇idea技术相关文章,由全栈君为大家提供,主要知识点是关于2021JetBrains全家桶永久激活码的内容IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.cn/100143.html41MD9IQHZL-eyJsa…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号