网站首页  词典首页

请输入您要查询的论文:

 

标题 正则表达式在python爬虫中的应用
范文

    苻玲美

    

    摘要:数据是新一轮技术革命最重要的生产资料,爬虫是获取数据最直接的方式,但爬出来的数据代码夹杂文字,面对大量杂乱的代码夹杂信息,通过正则表达式检索匹配出有用的信息,过滤无用的数据。本文介绍正则表达式在python爬虫中的应用,总结python爬虫中正则表达式的应用技巧。

    关键词:爬虫;python;正则表达式;数据

    中图分类号:TP311? ? 文献标识码:A

    文章编号:1009-3044(2019)25-0253-02

    网络爬虫是一个非常注重实践性而且实用性很强的编程技能,写爬虫分析股票走势,上链家爬房源分析房价趋势,爬知乎、爬豆瓣、爬新浪微博、爬影评,等等。人工智能时代,对数据的依赖越来越重要,数据主要的来源就是通过爬虫获取,通过爬取获取数据可以进行市场调研和数据分析。但爬虫时收集回来的一般是字符流,我们需要从中筛选有用的信息,而用正则表达式可以轻松地完成这一任务。

    1正则表达式与爬虫

    爬虫四个主要步骤:

    · 明确目标 (要知道你准备在哪个范围或者网站去搜索)

    · 爬 (将所有的网站的内容全部爬下来)

    · 取 (获取有用信息、去掉没用的数据)

    · 处理数据(按照我们想要的方式存储和使用)

    那么在取(文本过滤这块)最强大的就是正则表达式,更是python爬虫世界必不可少利器。

    什么是正则表达式,python爬虫使用正则表达式的方法。

    正则表达式(Regular Expression,简称Regex或RE)又称为正规表示法或常规表示法,常常用来检索、替换那些符合某个模式的文本,它首先设定好了一些特殊的字及字符组合,通过组合的“规则字符串”来对表达式进行过滤,从而获取或匹配我们想要的特定内容。它具有灵活、逻辑性和功能性非常的强,能迅速地通过表达式从字符串中找到所需信息的优点。

    正则表达式的常见语法格式:

    在 Python 中,我们可以使用内置的 re 模块来使用正则表达式。re模块提供了3个方法对输入的字符串进行确切的不同要求查询。每一个方法都接收一个正则表达式和一个待查找匹配的字符串。

    (1)match()方法- 从头匹配:

    match()方法的工作方式是只有当被搜索字符串的开头匹配模式的时候它才能查找到匹配对象。

    (2)使用re.search查找 – 匹配任意位置:

    search()方法和match()类似,不过search()方法不会限制我们只从字符串的开头查找匹配。search()方法会在它查找到一个匹配项之后停止继续查找。

    (3)使用 re.findall – 所有匹配对象:

    在Python中我使用的最多的查找方法是findall()方法。当我们调用findall()方法,我们可以非常简单地得到一个所有匹配模式的列表,

    2 正则表达式抓取网络数据常见方法

    在 HTML 中, 基本上所有的实体内容, 都会有个成对的 tag 来框住它。 而这个被 tag 住的内容, 就可以被展示成不同的形式。header 和 body。 在 header 中, 存放这一些网页的网页的元信息, 比如说 title, 这些信息是不会被显示到你看到的网页中的. 这些信息大多数时候是给浏览器看, 或者是给搜索引擎的爬虫看。HTML 的第二大块是 body, 这个部分才是你看到的网页信息。网页中的视频, 图片和文字等都存放在这里。 tag 就是主标题, 我们看到呈现出来的效果就是大一号的字。 里面的文字就是一个段落。 里面都是一些链接。是层用来存放一块信息。在html还有很多这样的tag,信息都是放在这些 tag 中的。爬虫想要做的就是根据这些 tag 来找到合适的信息。

    1)爬取网页

    通过下列操作成功爬取了百度的首页。

    2) 抓取title标签间的内容

    Print data打印出来抓取的网页,这就证明了我们能够成功读取这个网页的所有信息了。但我们还没有对网页的信息进行汇总和利用。我们发现想要提取一些形式的信息,合理的利用 tag 的名字十分重要。我们想用代码找到这个网页的 title,选好要使用的 tag 名称 。 使用正则匹配。</p><p>    title=re.findall(r"<title>(.+?)", data)

    print(title[0])

    3)抓取

    标签间的内容

    想要找到中间的那个段落

    的内容跟一样,但因为这个段落在 HTML 中还夹杂着 tab, new line, 所以我们给一个flags=re.DOTALL 来对这些 tab, new line 不敏感。</p><p>    4)爬取所有的连接的网址。</p><p>    有些时候,我们需要获取网站中所有的超链接并保存在文档里进行应用。一个一个获取是不现实的,我们把网页爬取出来后,用正则表达式去在索出来。超链接在网页中的格式是:你好,请登录。网址以href=“开头,以”结束。因此正则表达p=re.findall(rhref=”(.*?)”),data),其中data存放抓取的网页信息,r进行转义。</p><p>    3 总结</p><p>    大数据时代,我们需要海量的信息去分析市场、分析客户。而爬虫获取的数据掺杂着大量的代码和没用的数据。通过 正则表达式筛选有用的信息,过滤无用的数据。本文介绍爬虫与正则表达式的关系,正则表达式的语法,re模块的几种应用正则表达式方法的区别。最后通过案例总结了python爬虫中正则表达式的使用技巧。</p><p>    参考文献:</p><p>    [1]熊畅.基于Python爬虫技术的网页数据抓取与分析研究[J]. 数字技术与应用,2017(9):45-46.</p><p>    [2]魏冬梅,何忠秀,唐建梅.基于Python的Web信息获取方法研究[J].软件导刊,2018, 17(1):41-43.</p><p>    [3]万磊,严道波,杨勇,等.基于文本挖掘的95598投訴工单关键信息提取分析[J].电力与能源,2019,40(01):76-78.</p><p>    [4]Jeffrey E.F.Friedl(著).精通正则表达式[M].余晟,译.北京:电子工业出版社,2008.</p><p>    【通联编辑:闻翔军】</p> </td> </tr> <tr> <td width="61" align="center">随便看</td> <td> <ul class="random"> <li><a target="_blank" href="d110098.html">大型燃煤电厂大气污染物近零排放优化研究</a></li> <li><a target="_blank" href="d110099.html">危险废物焚烧处置废气污染物净化技术应用研究</a></li> <li><a target="_blank" href="d110100.html">云南某铅锌矿地质特征</a></li> <li><a target="_blank" href="d110101.html">节能给排水技术在市政公用工程中的实践探究</a></li> <li><a target="_blank" href="d110102.html">土木工程施工技术的创新及发展分析</a></li> <li><a target="_blank" href="d110103.html">刍议BIM技术在土木工程安全管理中的应用</a></li> <li><a target="_blank" href="d110104.html">“三软”煤层上保护层开采煤岩应力应变研究</a></li> <li><a target="_blank" href="d110105.html">城市交通规划和城市规划的协调关系</a></li> <li><a target="_blank" href="d110106.html">浅谈建筑工程施工中的安全控制管理</a></li> <li><a target="_blank" href="d110107.html">基于精益建造理论的BIM技术发展研究</a></li> <li><a target="_blank" href="d110108.html">负载敏感技术在工程机械行驶液压驱动系统的应用</a></li> <li><a target="_blank" href="d110109.html">线路维修中常见的几种晃车与整治办法</a></li> <li><a target="_blank" href="d110110.html">试析煤矿地质与防治水工作结合的必要性</a></li> <li><a target="_blank" href="d110111.html">水工大体积混凝土结构温度裂缝控制技术研究</a></li> <li><a target="_blank" href="d110112.html">试析土木工程建筑施工技术的创新措施</a></li> <li><a target="_blank" href="d110113.html">研究市政工程施工现场管理难点及改进措施</a></li> <li><a target="_blank" href="d110114.html">煤炭采掘工艺技术创新分析</a></li> <li><a target="_blank" href="d110115.html">煤矿安全事故原因及防范措施探析</a></li> <li><a target="_blank" href="d110116.html">某装配式混凝土框架结构设计实例分析</a></li> <li><a target="_blank" href="d110117.html">建筑物防雷规范应用实例</a></li> <li><a target="_blank" href="d110118.html">浅谈骨架密实型水泥稳定碎石基层在公路大修工程中的应用</a></li> <li><a target="_blank" href="d110119.html">某超高层剪力墙住宅结构抗震设计要点分析</a></li> <li><a target="_blank" href="d110120.html">建筑工程造价的动态管理与控制探析</a></li> <li><a target="_blank" href="d110121.html">浅谈土木工程房屋建设中深基坑支护技术的应用</a></li> <li><a target="_blank" href="d110122.html">探矿工程在地质资源勘查研究中的作用</a></li> <li><a target="_blank" href="9020.html">affixers</a></li> <li><a target="_blank" href="9021.html">affixes</a></li> <li><a target="_blank" href="9022.html">affixing</a></li> <li><a target="_blank" href="9023.html">affixment</a></li> <li><a target="_blank" href="9024.html">affixments</a></li> <li><a target="_blank" href="9025.html">affix-to</a></li> <li><a target="_blank" href="9026.html">afflict</a></li> <li><a target="_blank" href="9027.html">afflicted</a></li> <li><a target="_blank" href="9028.html">afflictedness</a></li> <li><a target="_blank" href="9029.html">afflictednesses</a></li> <li><a target="_blank" href="9030.html">afflicter</a></li> <li><a target="_blank" href="9031.html">afflicters</a></li> <li><a target="_blank" href="9032.html">afflicting</a></li> <li><a target="_blank" href="9033.html">afflictingly</a></li> <li><a target="_blank" href="9034.html">affliction</a></li> <li><a target="_blank" href="9035.html">afflictionless</a></li> <li><a target="_blank" href="9036.html">afflictions</a></li> <li><a target="_blank" href="9037.html">afflicts</a></li> <li><a target="_blank" href="9038.html">affluence</a></li> <li><a target="_blank" href="9039.html">affluent</a></li> <li><a target="_blank" href="9040.html">affluently</a></li> <li><a target="_blank" href="9041.html">affluents</a></li> <li><a target="_blank" href="9042.html">afford</a></li> <li><a target="_blank" href="9043.html">affordabilities</a></li> <li><a target="_blank" href="9044.html">affordability</a></li> <li><a target="_blank" href="b355729.html">溜亮</a></li> <li><a target="_blank" href="b355730.html">溜儿湫儿的</a></li> <li><a target="_blank" href="b355731.html">溜光</a></li> <li><a target="_blank" href="b355732.html">溜光光</a></li> <li><a target="_blank" href="b355733.html">溜光冰滑</a></li> <li><a target="_blank" href="b355734.html">溜光水滑</a></li> <li><a target="_blank" href="b355735.html">溜光罄净</a></li> <li><a target="_blank" href="b355736.html">溜光罄尽</a></li> <li><a target="_blank" href="b355737.html">溜光锤</a></li> <li><a target="_blank" href="b355738.html">溜冰</a></li> <li><a target="_blank" href="b355739.html">溜冰场</a></li> <li><a target="_blank" href="b355740.html">溜净</a></li> <li><a target="_blank" href="b355741.html">溜刷在行</a></li> <li><a target="_blank" href="b355742.html">溜勾子</a></li> <li><a target="_blank" href="b355743.html">溜号</a></li> <li><a target="_blank" href="b355744.html">溜号儿</a></li> <li><a target="_blank" href="b355745.html">溜哄</a></li> <li><a target="_blank" href="b355746.html">溜啦</a></li> <li><a target="_blank" href="b355747.html">溜圆</a></li> <li><a target="_blank" href="b355748.html">溜场</a></li> <li><a target="_blank" href="b355749.html">溜坡</a></li> <li><a target="_blank" href="b355750.html">溜垂</a></li> <li><a target="_blank" href="b355751.html">溜奥</a></li> <li><a target="_blank" href="b355752.html">溜子</a></li> <li><a target="_blank" href="b355753.html">溜子海</a></li> </ul> </td> </tr> </table> <p> </p> <p>科学优质学术资源、百科知识分享平台,免费提供知识科普、生活经验分享、中外学术论文、各类范文、学术文献、教学资料、学术期刊、会议、报纸、杂志、工具书等各类资源检索、在线阅读和软件app下载服务。<p> </p> <div class="foot">Copyright © 2004-2023 puapp.net All Rights Reserved<BR> <span class="updatetime"> 更新时间:2026/5/30 7:04:14</span><script src="/js/count.js" type="text/javascript"></script></div> </body> </html>