当前位置: 首页 > news >正文

重庆属于哪个省china东莞seo

重庆属于哪个省,china东莞seo,seo新手入门教程,毕节市城乡住房建设网站python爬虫7#xff1a;实战1 前言 ​ python实现网络爬虫非常简单#xff0c;只需要掌握一定的基础知识和一定的库使用技巧即可。本系列目标旨在梳理相关知识点#xff0c;方便以后复习。 申明 ​ 本系列所涉及的代码仅用于个人研究与讨论#xff0c;并不会对网站产生不好…python爬虫7实战1 前言 ​ python实现网络爬虫非常简单只需要掌握一定的基础知识和一定的库使用技巧即可。本系列目标旨在梳理相关知识点方便以后复习。 申明 ​ 本系列所涉及的代码仅用于个人研究与讨论并不会对网站产生不好影响。 目录结构 文章目录 python爬虫7实战11. 目标2. 详细流程2.1 找到目标小说2.2 获取小说章节目录2.3 获取小说内容2.4 完整代码 3. 总结 1. 目标 ​ 这次爬虫实战采用的库为requests lxml这次以爬取一部小说为目标具体的网站老规矩就不给了大家学习思路最重要。 ​ 再次说明案例本身并不重要重要的是如何去使用和分析另外为了避免侵权之类的问题我不会放涉及到网站的图片希望能理解。 2. 详细流程 2.1 找到目标小说 第一步确定get请求的url ​ 假设我们的网站为https://xxxxxxx.com那么我们首先需要找到搜索框然后随意搜索几本小说比如这里我搜索的是圣墟、万族之劫那么观察网页上的url变化如下 https://xxxxx?q圣墟 https://xxxxx?q万族之劫​ 可以看出这里是get请求并且参数名为q。 第二步正确请求网页 ​ 我们可以写下第一个代码了目标是获取想要的小说代码如下 # 都要用到的参数 HEADERS {User-Agent : Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/115.0.0.0 Safari/537.36, }# 获取搜索某小说后的页面 def get_search_result():# 网址url xxxxx# 请求参数search input(请输入想要搜索的小说)params {q : search}# 请求response requests.get(url,headersHEADERS,paramsparams)# 把获取到的网页保存到本地with open(search.html,w,encodingutf-8) as f:f.write(response.content.decode(utf-8))​ 结果如下 ​ 可以看出获取到正确的网页说明这一步我们完成了。 正确解析网页以获取小说链接 ​ 上面我们已经把网页源码存放到了本地一个名为search.html的文件下面我们来解析它。 ​ 解析它首先需要明确我们要获取什么节点、什么值。看下面 ​ 可以看出我们的目标标签位于div[classmshow]下的table[classgrid]下的td下的a标签并且我们需要获取这个a标签的href属性和文本值。除此之外href属性值只是部分地址需要跟网站根地址xxxx.com拼凑再一起。 ​ 基于此可以完成代码 # 解析网页 def parse_search_result():# 打开文件读取文件with open(search.html,r,encodingutf-8) as f:content f.read()# 基础urlbase_url xxxxxx.com/# 初始化lxmlhtml etree.HTML(content)# 获取目标节点href_list html.xpath(//div[classshow]//table[classgrid]//td//a/href)text_list html.xpath(//div[classshow]//table[classgrid]//td//a/text())# 处理内容值url_list [base_urlhref for href in href_list]# 选择要爬取的小说for i,text in enumerate(text_list):print(当前小说名为,text)decision input(是否爬取它只能选择一本,Y/N)if decision Y:return url_list[i],text​ 运行结果如下 2.2 获取小说章节目录 第一步请求页面 ​ 首先我们去请求上面获取的网页这里就比较简单了基本上把上面的请求代码拷贝过来修改修改即可 # 请求目标小说网站 def get_target_book(url):# 请求response requests.get(url,headersHEADERS)# 保存源码with open(book.html,w,encodingutf-8) as f:f.write(response.content.decode(utf-8))​ 可以看到保存到本地的结果如下 ​ 可以看出这一步成功了。 第二步解析上面的网页获取不同章节的链接 ​ 这一步主要的难点在于解析网页首先看下面 ​ 由于该网页小说章节都分为两个部位第一个为最新章节第二个为全部章节而第二个才是我们需要获取的因此xpath语法应该为 //div[classshow]//div[contains(class,showBox) and position()3]//ul//a​ 那么可以完成代码如下 # 解析章节网页 def parse_chapter(base_url):# 打开文件读取内容with open(book.html,r,encodingutf-8) as f:content f.read()# 初始化html etree.HTML(content)# 解析href_list html.xpath(//div[classshow]//div[contains(class,showBox) and position()3]//ul//a/href)text_list html.xpath(//div[classshow]//div[contains(class,showBox) and position()3]//ul//a/text())# 处理拼凑出完整网页url_list [base_urlurl for url in href_list]# 返回结果return url_list,text_list​ 运行结果如下 2.3 获取小说内容 ​ 这里我们就不分开了直接获取源码后直接解析。那么这里说明一下解析原理看下面 ​ 可以轻松知道xpath语法 //div[contains(class,book)]//div[idcontent]//text()​ 那么代码如下 # 请求小说页面 def get_content(url,title):# 请求response requests.get(url,headersHEADERS)# 获取源码content response.content.decode(utf-8)# 初始化html etree.HTML(content)# 解析text_list html.xpath(//div[contains(class,book)]//div[idcontent]//text())# 后处理# 首先把第一个和最后一个的广告信息去掉text_list text_list[1:-1]# 其次把里面的空白字符和\xa0去掉text_list [text.strip().replace(\xa0,) for text in text_list]# 最后写入文件即可with open(title.txt,w,encodingutf-8) as g:for text in text_list:g.write(text\n)​ 运行结果如下 ​ 可以看出成功实现。 2.4 完整代码 ​ 完整代码如下 # author : 自学小白菜 # -*- coding:utf-8 -*- # File Name : 7 lxml_novel.py # Create Time : 2023/8/5 22:04 # Version : python3.7 # Description : 实战1爬取小说 # 导包 import requests from lxml import etree# 都要用到的参数 HEADERS {User-Agent : Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/115.0.0.0 Safari/537.36, }# 获取搜索某小说后的页面 def get_search_result():# 网址url https://www.iwurexs.net/so.html# 请求参数search input(请输入想要搜索的小说)params {q : search}# 请求response requests.get(url,headersHEADERS,paramsparams)# 把获取到的网页保存到本地with open(search.html,w,encodingutf-8) as f:f.write(response.content.decode(utf-8))# 解析网页 def parse_search_result():# 打开文件读取文件with open(search.html,r,encodingutf-8) as f:content f.read()# 基础urlbase_url https://www.iwurexs.net/# 初始化lxmlhtml etree.HTML(content)# 获取目标节点href_list html.xpath(//div[classshow]//table[classgrid]//td//a/href)text_list html.xpath(//div[classshow]//table[classgrid]//td//a/text())# 处理内容值url_list [base_urlhref for href in href_list]# 选择要爬取的小说for i,text in enumerate(text_list):print(当前小说名为,text)decision input(是否爬取它只能选择一本,Y/N)if decision Y:return url_list[i],text# 请求目标小说网站 def get_target_book(url):# 请求response requests.get(url,headersHEADERS)# 保存源码with open(book.html,w,encodingutf-8) as f:f.write(response.content.decode(utf-8))# 解析章节网页 def parse_chapter(base_url):# 打开文件读取内容with open(book.html,r,encodingutf-8) as f:content f.read()# 初始化html etree.HTML(content)# 解析href_list html.xpath(//div[classshow]//div[contains(class,showBox) and position()3]//ul//a/href)text_list html.xpath(//div[classshow]//div[contains(class,showBox) and position()3]//ul//a/text())# 处理拼凑出完整网页url_list [base_urlurl for url in href_list]# 返回结果return url_list,text_list# 请求小说页面 def get_content(url,title):# 请求response requests.get(url,headersHEADERS)# 获取源码content response.content.decode(utf-8)# 初始化html etree.HTML(content)# 解析text_list html.xpath(//div[contains(class,book)]//div[idcontent]//text())# 后处理# 首先把第一个和最后一个的广告信息去掉text_list text_list[1:-1]# 其次把里面的空白字符和\xa0去掉text_list [text.strip().replace(\xa0,) for text in text_list]# 最后写入文件即可with open(title.txt,w,encodingutf-8) as g:for text in text_list:g.write(text\n)if __name__ __main__:# 第一步获取到搜索页面的源码# get_search_result()# 第二步进行解析target_url,name parse_search_result()# 第三步请求目标小说页面get_target_book(target_url)# 第四步解析章节网页url_list,text_list parse_chapter(target_url)for url,title in zip(url_list,text_list):# 第五步请求小说具体的某个章节并直接解析get_content(url,title)break3. 总结 ​ 上面代码还不完善存在一定优化的地方比如代码有些地方可以解耦另外必须限制访问速度不然后期容易被封掉IP除此之外可以考虑代理池构建等操作。
http://www.hkea.cn/news/14513495/

相关文章:

  • 电子商务和网站建设方案wordpress超级留言版
  • 双牌网站建设网站开发工程师岗位说明书
  • 金融理财网站建设科技小制作 手工 简单
  • 专业的网站建设宝安西乡如何制作app软件步骤
  • 电子商务网站建设各项费用预算是多少烟台网站建设技术托管
  • 网站续费模版网站建设的售后服务
  • 地方志网站建设甘肃网站备案审核
  • 做汽车价格的网站wordpress 新浪微博
  • saas建站 cms单县住房和城乡建设局网站
  • 个人网站作品下载网站建设与网页设计大作业
  • 郑州汽车网站建设哪家好最新军事新闻报道
  • 网站建设与管理试题及答案芜湖龙湖建设工程有限公司网站
  • 网站制作公司服务东莞怎样做网站建设
  • 企石网站建设注册公司的流程图
  • 腾讯理财是什么样的做网站江门网站建设设计
  • 企业培训师资格证网络优化主要做什么
  • aap手机网站建设个人微博网页制作代码教程
  • 陕西十二建设有限公司网站怎么制作网站教程步骤视频
  • 有没有做皮艺的网站预算有哪些网站做私活
  • 做好网站功能性建设工作微商网站如何做推广方案
  • 做网站的出路wordpress 动作钩子
  • 2003建网站做网站软件j
  • 国外代理网站外贸推广引流系统
  • 沧州网站建设代理价格wordpress网站加速
  • 网站模板html 汽车膜wordpress 文章长度
  • 产品网站怎么做网络广告的特点是
  • 顺义网站做的比较好的公司网站初期建设的成本来源
  • 北京网站建设公司拟网站建设怎么配置伪静态文件
  • html的网站模板下载wordpress域名如何申请
  • 珠海网站设计费用湖南建设门户网站