Python爬虫实现网页信息抓取功能示例【URL与正则模块】

发布时间 - 2026-01-11 01:10:01    点击率:

本文实例讲述了Python爬虫实现网页信息抓取功能。分享给大家供大家参考,具体如下:

首先实现关于网页解析、读取等操作我们要用到以下几个模块

import urllib
import urllib2
import re

我们可以尝试一下用readline方法读某个网站,比如说百度

def test():
  f=urllib.urlopen('http://www.baidu.com')
  while True:
   firstLine=f.readline()
   print firstLine

下面我们说一下如何实现网页信息的抓取,比如说百度贴吧

我们大概要做几件事情:

首先获取网页及其代码,这里我们要实现多页,即其网址会改变,我们传递一个页数

  def getPage(self,pageNum):
     try:
        url=self.baseURL+self.seeLZ+'&pn='+str(pageNum)
        #创建request对象
        request=urllib2.Request(url)
        response=urllib2.urlopen(request)
        #print 'URL:'+url
        return response.read()
     except Exception,e:
        print e

之后我们要获取小说内容,这里咱们分为标题和正文。标题每页都有,所以我们获取一次就好了。

我们可以点击某网站,按f12查看他的标题标签是如何构造的,比如说百度贴吧是<title>…………

那我们就匹配reg=re.compile(r'<title>(.*?)。')来抓取这个信息

标题抓取完我们要开始抓去正文了,我们知道正文会有很多段,所以我们要循环的去抓取整个items,这里我们注意

对于文本的读写操作,一定要放在循环外。同时加入一些去除超链接、<br>等机制

最后,我们在主函数调用即可

完整代码:

# -*- coding:utf-8 -*-
import sys
reload(sys)
sys.setdefaultencoding('utf8')
#爬虫之网页信息抓取
#需要的函数方法:urllib,re,urllib2
import urllib
import urllib2
import re
#测试函数->读取
#def test():
#   f=urllib.urlopen('http://www.baidu.com')
#   while True:
#     firstLine=f.readline()
#     print firstLine
#针对于百度贴吧获取前十页楼主小说文本内容
class BDTB:
   def __init__(self,baseUrl,seeLZ):
     #成员变量
     self.baseURL=baseUrl
     self.seeLZ='?see_lz='+str(seeLZ)
   #获取该页帖子的代码
   def getPage(self,pageNum):
     try:
        url=self.baseURL+self.seeLZ+'&pn='+str(pageNum)
        #创建request对象
        request=urllib2.Request(url)
        response=urllib2.urlopen(request)
        #print 'URL:'+url
        return response.read()
     except Exception,e:
        print e
   #匹配标题
   def Title(self):
     html=self.getPage(1)
     #compile提高正则匹配效率
     reg=re.compile(r'<title>(.*?)。')
     #返回list列表
     items=re.findall(reg,html)
     f=open('output.txt','w+')
     item=('').join(items)
     f.write('\t\t\t\t\t'+item.encode('gbk'))
     f.close()
   #匹配正文
   def Text(self,pageNum):
     html=self.getPage(pageNum)
     #compile提高正则匹配效率
     reg=re.compile(r'"d_post_content j_d_post_content ">(.*?)</div>')
     #返回list列表
     items=re.findall(reg,html)
     f=open('output.txt','a+')
     #[1:]切片,第一个元素不需要,去掉。
     for i in items[1:]:
        #超链接去除
        removeAddr=re.compile('<a.*?>|</a>')
        #用""替换
        i=re.sub(removeAddr,"",i)
        #<br>去除
        i=i.replace('<br>','')
        f.write('\n\n'+i.encode('gbk'))
     f.close()
#调用入口
baseURL='http://tieba.baidu.com/p/4638659116'
bdtb=BDTB(baseURL,1)
print '爬虫正在启动....'.encode('gbk')
#多页
bdtb.Title()
print '抓取标题完毕!'.encode('gbk')
for i in range(1,11):
  print '正在抓取第%02d页'.encode('gbk')%i
  bdtb.Text(i)
print '抓取正文完毕!'.encode('gbk')

PS:这里再为大家提供2款非常方便的正则表达式工具供大家参考使用:

JavaScript正则表达式在线测试工具:
http://tools./regex/javascript

正则表达式在线生成工具:
http://tools./regex/create_reg

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

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


# Python  # 爬虫  # 网页信息  # 抓取  # URL  # 正则  # 模块  # python3正则模块re的使用方法详解  # Python3中正则模块re.compile、re.match及re.search函数用法详解  # Python 正则模块详情  # 贴吧  # 我们可以  # 正则表达式  # 超链接  # 进阶  # 操作技巧  # 多页  # 几个  # 都有  # 会有  # 放在  # 相关内容  # 第一个  # 不需要  # 每页  # 数据结构  # 要做  # 给大家  # 要用  # 更多关于 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Python3.6正式版新特性预览  如何彻底卸载建站之星软件?  Laravel怎么实现观察者模式Observer_Laravel模型事件监听与解耦开发【指南】  教学论文网站制作软件有哪些,写论文用什么软件 ?  html文件怎么打开证书错误_https协议的html打开提示不安全【指南】  深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?  Laravel Seeder怎么填充数据_Laravel数据库填充器的使用方法与技巧  php静态变量怎么调试_php静态变量作用域调试技巧【解答】  Win11搜索不到蓝牙耳机怎么办 Win11蓝牙驱动更新修复【详解】  javascript中数组(Array)对象和字符串(String)对象的常用方法总结  如何用PHP工具快速搭建高效网站?  HTML透明颜色代码在Angular里怎么设置_Angular透明颜色使用指南【详解】  EditPlus中的正则表达式 实战(2)  Edge浏览器如何截图和滚动截图_微软Edge网页捕获功能使用教程【技巧】  js代码实现下拉菜单【推荐】  Laravel怎么为数据库表字段添加索引以优化查询  Win11应用商店下载慢怎么办 Win11更改DNS提速下载【修复】  网站制作企业,网站的banner和导航栏是指什么?  网站制作壁纸教程视频,电脑壁纸网站?  千库网官网入口推荐 千库网设计创意平台入口  HTML5段落标签p和br怎么选_文本排版常用标签对比【解答】  高端网站建设与定制开发一站式解决方案 中企动力  Laravel怎么上传文件_Laravel图片上传及存储配置  JavaScript如何操作视频_媒体API怎么控制播放  如何在景安云服务器上绑定域名并配置虚拟主机?  猎豹浏览器开发者工具怎么打开 猎豹浏览器F12调试工具使用【前端必备】  Laravel如何使用Collections进行数据处理?(实用方法示例)  QQ浏览器网页版登录入口 个人中心在线进入  企业网站制作这些问题要关注  HTML5空格和nbsp有啥关系_nbsp的作用及使用场景【说明】  手机网站制作与建设方案,手机网站如何建设?  详解jQuery中基本的动画方法  Laravel事件监听器怎么写_Laravel Event和Listener使用教程  Laravel如何处理和验证JSON类型的数据库字段  微信h5制作网站有哪些,免费微信H5页面制作工具?  Laravel如何为API生成Swagger或OpenAPI文档  🚀拖拽式CMS建站能否实现高效与个性化并存?  Windows11怎样设置电源计划_Windows11电源计划调整攻略【指南】  Laravel怎么使用Collection集合方法_Laravel数组操作高级函数pluck与map【手册】  ,交易猫的商品怎么发布到网站上去?  微信小程序 配置文件详细介绍  成都网站制作公司哪家好,四川省职工服务网是做什么用?  如何在沈阳梯子盘古建站优化SEO排名与功能模块?  Laravel如何升级到最新的版本_Laravel版本升级流程与兼容性处理  如何在阿里云完成域名注册与建站?  iOS验证手机号的正则表达式  Laravel如何实现API版本控制_Laravel API版本化路由设计策略  Laravel如何设置定时任务(Cron Job)_Laravel调度器与任务计划配置  Laravel如何优化应用性能?(缓存和优化命令)  Laravel怎么解决跨域问题_Laravel配置CORS跨域访问