经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » Python3 » 查看文章
Python3爬虫爬取百姓网列表并保存为json功能示例【基于request、lxml和json模块】
来源:jb51  时间:2018/12/6 10:04:29  对本文有异议

本文实例讲述了Python3爬虫爬取百姓网列表并保存为json功能。分享给大家供大家参考,具体如下:

python3爬虫之爬取百姓网列表并保存为json文件。这几天一直在学习使用python3爬取数据,今天记录一下,代码很简单很容易上手。

首先需要安装python3。如果还没有安装,可参考jb51python3安装与配置相关文章。

首先需要安装requestslxmljson三个模块

需要手动创建d.json文件

代码

  1. import requests
  2. from lxml import etree
  3. import json
  4. #构造头文件,模拟浏览器访问
  5. url="http://xian.baixing.com/meirongfuwu/"
  6. headers = {'User-Agent':'Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.77 Safari/537.36','referer':url}
  7. response=requests.get(url,headers=headers)
  8. body=response.text #获取网页内容
  9. html=etree.HTML(body,etree.HTMLParser())
  10. gethtml=html.xpath('//div[contains(@class,"media-body-title")]')
  11. # 存储为数组list
  12. jsondata = []
  13. for item in gethtml:
  14. jsonone={}
  15. jsonone['title']=item.xpath('.//a[contains(@class,"ad-title")]/text()')[0]
  16. jsonone['url']=item.xpath('.//a[contains(@class,"ad-title")]/attribute::href')[0]
  17. jsonone['phone']=item.xpath('.//button[contains(@class,"contact-button")]/attribute::data-contact')[0]
  18. jsondata.append(jsonone)
  19. # 保存为json
  20. with open("./d.json",'w',encoding='utf-8') as json_file:
  21. json.dump(jsondata,json_file,ensure_ascii=False)
  22.  

结果

PS:这里再为大家推荐几款比较实用的json在线工具供大家参考使用:

在线JSON代码检验、检验、美化、格式化工具:
http://tools.jb51.net/code/json

JSON在线格式化工具:
http://tools.jb51.net/code/jsonformat

在线XML/JSON互相转换工具:
http://tools.jb51.net/code/xmljson

json代码在线格式化/美化/压缩/编辑/转换工具:
http://tools.jb51.net/code/jsoncodeformat

在线json压缩/转义工具:
http://tools.jb51.net/code/json_yasuo_trans

更多关于Python相关内容可查看jb51专题:《Python Socket编程技巧总结》、《Python正则表达式用法总结》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》、《Python入门与进阶经典教程》及《Python文件与目录操作技巧汇总

希望本文所述对大家Python程序设计有所帮助。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号