Python爬虫——生成HTML文件

导入需要的库

import pandas as pd
import requests
import urllib3
from pyecharts.charts import Bar, Line, WordCloud, Page
from pyecharts import options as opts

爬虫

urllib3.disable_warnings()# 屏蔽https证书警告
url = "http://www.stats.gov.cn/ztjc/zdtjgz/zgrkpc/dqcrkpc/ggl/202105/t20210519_1817697.html"
response = requests.get(url, verify=False)#对url网址进行请求,verify当访问https页面出现证书错误,可以使用verify来取消验证
response.encoding = response.apparent_encoding#获取响应对象的编码格式
html = response.text#得到文本数据
data = pd.read_html(html)[0]#获取html中table标签的表格
data.to_excel('爬虫数据.xlsx')

数据清洗

data.columns = ['地区', '男', '女', '性别比']#把每一列的列表名改为'地区','男','女','性别比'
data.drop(data.index[0:2], inplace=True)#删除第一和第二行数据
city = list(data["地区"])#把名为“地区”的列拿出来命名为city
child = list(data["性别比"])#把名为“性别比”的列拿出来命名为child
people = [list(z) for z in zip(city, child)]#把city和child的数据打包放在people中
data.to_excel('数据分析.xlsx')

柱状图 

bar = (
    Bar()#引入bar这个类
    .add_xaxis(city)#x轴数据定义为city
    .add_yaxis("男女比例", child)#y轴数据定义为child
    .set_global_opts(title_opts=opts.TitleOpts(title="中国男女比例分布"))#生成柱状图的标题
)

折线图

line = (
    Line()#引入Line类
    .add_xaxis(city)#定义x轴的值
    .add_yaxis('男女比例', child, is_smooth=True)#定义y轴的值
    .set_global_opts(title_opts=opts.TitleOpts(title="中国男女比例折线图"))  # 生成折线图的标题
)

词云图

wordcloud = (
    WordCloud()#引入WordCloud类
    .add("", people, word_size_range=[20, 60])#定义词云的数据
    .set_global_opts(title_opts=opts.TitleOpts(title="中国男女比例词云图"))#生成词云的标题
)

生成HTML文件

page = Page(layout=Page.SimplePageLayout)#定义html中SimplePageLayout布局
page.add(
    bar,
    line,
    wordcloud,
)#把柱状图,折线图,词云图放在一个html中

page.render('中国男女比例分布.html')#生成一个名为中国男女比例分布的html文件

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

蝶恋花工作室

你的鼓励就是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值