找回密码
 会员注册
查看: 37|回复: 0

Python爬虫下载人生格言

[复制链接]

2万

主题

0

回帖

7万

积分

超级版主

积分
71769
发表于 2024-9-8 18:02:09 | 显示全部楼层 |阅读模式
Python爬虫:下载人生格言爬取网页将这些格言下载存储到本地代码:importrequests#导入requests库,用于提取网页fromlxmlimportetree#导入lxml库,用于Xpath数据解析#请求头header={'user-agent':'Mozilla/5.0(WindowsNT10.0;Win64;x64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/127.0.0.0Safari/537.36Edg/127.0.0.0'}#每个浏览器的user-agent不一样,在浏览器中查找url="http://m.3chongmen.com/renshenggeyan/162.html"#请求网址res1=requests.get(url=url,headers=header).texthtml=etree.HTML(res1)title=html.xpath('//div[@class="title"]/h1/text()')[0]#数据解析,提取content=html.xpath('//div[@class="content"]/text()')#数据解析,提取内容content="".join(content)print(title)print(content)1234567891011121314151617运行结果:分析:导入requests库requests库是第三方库,要提前安装输入指令进行安装pipinstallrequests1*导入lxml库输入指令pipinstalllxml1headers最简单的只用加上user-agent就可以了鼠标右键,选择”检查“,点击”网络“,ctrl+R刷新页面,点击第一份文件,点击”标头“,滑到最下方查找”User-Agent“,复制到pycharm中即可数据解析Xpath用requets获取的源代码如图,想要的信息就在这里面,我们需要提取出来,因此就要用到Xpath进行解析,要先学习一下Xpath语法和lxml库的使用,可以在网上查找相关资料拓展将目录下的所有人生格言提取并保存在本地代码importrequestsfromlxmlimportetreeheader={'user-agent':'Mozilla/5.0(WindowsNT10.0;Win64;x64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/127.0.0.0Safari/537.36Edg/127.0.0.0'}defspider(url):res1=requests.get(url=url,headers=header).texthtml=etree.HTML(res1)content=html.xpath('//div[@class="content"]/text()')content="".join(content)title=html.xpath('//div[@class="title"]/h1/text()')[0]returntitle,contenturl1="http://m.3chongmen.com/renshenggeyan"res=requests.get(url=url1,headers=header).texthtml=etree.HTML(res)links=html.xpath('//ul[@class="list_cnt"]//a[@target="_blank"]/@href')forlinkinlinks:title,content=spider(link)withopen(f'格言/{title}.txt','w',encoding='utf-8')asf:f.write(title+'\n\n')f.write(content)1234567891011121314151617181920212223242526运行结果:
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 会员注册

本版积分规则

QQ|手机版|心飞设计-版权所有:微度网络信息技术服务中心 ( 鲁ICP备17032091号-12 )|网站地图

GMT+8, 2025-1-10 13:53 , Processed in 0.766775 second(s), 26 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表