Python基于pandas爬取网页表格数据
以网页表格为例:https://www.kuaidaili.com/free/
该网站数据存在table标签,直接用requests,需要结合bs4解析正则/xpath/lxml等,没有几行代码是搞不定的。
今天介绍的黑科技是pandas自带爬虫功能,pd.read_html(),只需传人url,一行代码搞定。
原网页结构如下:

python代码如下:
import pandas as pdurl=’http://www.kuaidaili.com/free/’df=pd.read_html(url)[0] # [0]:表示第一个table,多个table需要指定,如果不指定默认第一个# 如果没有【0】,输入dataframe格式组成的listdf
输出dataframe格式数据


再次保存到本地,csv格式,注意中文编码:utf_8_sig
print(type(df))df.to_csv(’free ip.csv’,mode=’a’, encoding=’utf_8_sig’, header=1, index=0)print(’done!’)
查看csv文件

先来了解一下read_html函数的api:
pandas.read_html(io, match=’.+’, flavor=None, header=None, index_col=None, skiprows=None, attrs=None, parse_dates=False, tupleize_cols=None, thousands=’, ’, encoding=None, decimal=’.’, converters=None, na_values=None, keep_default_na=True, displayed_only=True)
常用的参数:
io:可以是url、html文本、本地文件等; flavor:解析器; header:标题行; skiprows:跳过的行; attrs:属性,比如 attrs = {’id’: ’table’}; parse_dates:解析日期注意:返回的结果是**DataFrame**组成的**list**。
若要dataframe,直接取list【0】
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持好吧啦网。
相关文章:
1. Intellij IDEA如何去掉@Autowired 注入警告的方法2. .NET的基元类型包括什么及Unmanaged和Blittable类型详解3. IntelliJ IDEA 下载安装超详细教程(推荐)4. python GUI库图形界面开发之PyQt5中QWebEngineView内嵌网页与Python的数据交互传参详细方法实例5. SpringBoot + Vue 项目部署上线到Linux 服务器的教程详解6. IntelliJ IDEA恢复删除文件的方法7. 初学者如何快速搭建Express开发系统步骤详解8. java编写一个花名随机抽取器的实现示例9. 详解JavaScript是如何验证URL的10. 关于html嵌入xml数据岛如何穿过树形结构关系的问题

网公网安备