网站首页  词典首页

请输入您要查询的论文:

 

标题 正则表达式在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="d252867.html">不同种类有机肥在大棚莴苣上的肥效试验研究</a></li> <li><a target="_blank" href="d252868.html">酿造型专用糯高粱新品种</a></li> <li><a target="_blank" href="d252869.html">鸡群发生消化不良的主要原因与防治措施</a></li> <li><a target="_blank" href="d252870.html">兔皮肤真菌病的诊断与防治</a></li> <li><a target="_blank" href="d252871.html">一例猪增生性回肠炎的临床诊疗报告</a></li> <li><a target="_blank" href="d252872.html">肉鸭绿色养殖终结“填鸭”式饲养</a></li> <li><a target="_blank" href="d252873.html">甘肃着力促进中医药产业与现代农业融合</a></li> <li><a target="_blank" href="d252874.html">白羽肉鸡助推我国肉鸡产业转型升级</a></li> <li><a target="_blank" href="d252875.html">袁隆平领衔攻关第三代杂交稻取得重大突破首次测产平均亩产1046.3千克</a></li> <li><a target="_blank" href="d252876.html">安徽再生稻示范田实现亩产吨粮</a></li> <li><a target="_blank" href="d252877.html">致富路上显身手巾帼创业谱新篇</a></li> <li><a target="_blank" href="d252878.html">情满果园铺就致富路</a></li> <li><a target="_blank" href="d252879.html">大足区:绘制一幅乡村振兴“工笔画”</a></li> <li><a target="_blank" href="d252880.html">高绿香荼的采制技术</a></li> <li><a target="_blank" href="d252881.html">油菜冬季长势过旺春季如何管理</a></li> <li><a target="_blank" href="d252882.html">远志绿色高产栽培技术</a></li> <li><a target="_blank" href="d252883.html">邹城市冬小麦科学播种技术</a></li> <li><a target="_blank" href="d252884.html">邳州市绿色优质水稻生产技术规程</a></li> <li><a target="_blank" href="d252885.html">打破低产瓶颈 山区小豌豆也有大作为</a></li> <li><a target="_blank" href="d252886.html">利用中草药提高蛋鸡产蛋率的实用配方</a></li> <li><a target="_blank" href="d252887.html">提高雏鹅成活率的主要措施</a></li> <li><a target="_blank" href="d252888.html">宁夏农村电商网络零售增长快</a></li> <li><a target="_blank" href="d252889.html">黄淮海夏大豆百亩实收亩产超300千克</a></li> <li><a target="_blank" href="d252890.html">世界农场动物福利大会连续三年在我国举办</a></li> <li><a target="_blank" href="d252891.html">马铃薯绿色发展技术集成模式研究取得新进展</a></li> <li><a target="_blank" href="130221.html">not have a job/be without a job</a></li> <li><a target="_blank" href="130222.html">not have any more/not have any left</a></li> <li><a target="_blank" href="130223.html">not have anywhere to live</a></li> <li><a target="_blank" href="130224.html">not have enough</a></li> <li><a target="_blank" href="130225.html">not have the faintest/slightest/foggiest idea</a></li> <li><a target="_blank" href="130226.html">not have the guts</a></li> <li><a target="_blank" href="130227.html">not have the nerve</a></li> <li><a target="_blank" href="130228.html">not have the power to do sth/it is not in your power to do sth</a></li> <li><a target="_blank" href="130229.html">not have (the) time/have no time</a></li> <li><a target="_blank" href="130230.html">not have the time/have no time</a></li> <li><a target="_blank" href="130231.html">not have time/have no time</a></li> <li><a target="_blank" href="130232.html">not have/want anything to do with</a></li> <li><a target="_blank" href="130233.html">palmsize</a></li> <li><a target="_blank" href="130234.html">palm-size</a></li> <li><a target="_blank" href="130235.html">palm sth off on</a></li> <li><a target="_blank" href="130236.html">palm sth off (on/onto sb)</a></li> <li><a target="_blank" href="130237.html">palm sth off (on sb)</a></li> <li><a target="_blank" href="130238.html">palmtop</a></li> <li><a target="_blank" href="130239.html">palm tree</a></li> <li><a target="_blank" href="130240.html">palm²</a></li> <li><a target="_blank" href="130241.html">palm¹</a></li> <li><a target="_blank" href="130242.html">palpabilities</a></li> <li><a target="_blank" href="130243.html">palpable</a></li> <li><a target="_blank" href="130244.html">palpableness</a></li> <li><a target="_blank" href="130245.html">palpablenesses</a></li> <li><a target="_blank" href="b209996.html">峰回路转</a></li> <li><a target="_blank" href="b209997.html">峰头</a></li> <li><a target="_blank" href="b209998.html">峰岫</a></li> <li><a target="_blank" href="b209999.html">峰峦</a></li> <li><a target="_blank" href="b210000.html">峰峦与山谷极多</a></li> <li><a target="_blank" href="b210001.html">峰峦相接,连绵重叠</a></li> <li><a target="_blank" href="b210002.html">峰崖环绕的山谷</a></li> <li><a target="_blank" href="b210003.html">峰嶂</a></li> <li><a target="_blank" href="b210004.html">峰巅</a></li> <li><a target="_blank" href="b210005.html">峰巘</a></li> <li><a target="_blank" href="b210006.html">峰年</a></li> <li><a target="_blank" href="b210007.html">峰朵</a></li> <li><a target="_blank" href="b210008.html">峰极</a></li> <li><a target="_blank" href="b210009.html">峰立</a></li> <li><a target="_blank" href="b210010.html">峰胁</a></li> <li><a target="_blank" href="b210011.html">峰脊</a></li> <li><a target="_blank" href="b210012.html">峰脚</a></li> <li><a target="_blank" href="b210013.html">峰谷</a></li> <li><a target="_blank" href="b210014.html">峰顶</a></li> <li><a target="_blank" href="b210015.html">峱</a></li> <li><a target="_blank" href="b210016.html">峴</a></li> <li><a target="_blank" href="b210017.html">島</a></li> <li><a target="_blank" href="b210018.html">峻</a></li> <li><a target="_blank" href="b210019.html">峻丽</a></li> <li><a target="_blank" href="b210020.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"> 更新时间:2025/8/30 5:02:52</span><script src="/js/count.js" type="text/javascript"></script></div> </body> </html>