Python URL过滤:利用正则表达式实现关键词精确匹配

Python URL过滤:利用正则表达式实现关键词精确匹配

本教程旨在解决在python中过滤url时遇到的关键词部分匹配问题。通过详细讲解如何使用正则表达式(`re`模块)结合词边界符或非字母字符边界,实现对url路径中指定关键词的精确匹配,从而避免诸如’join’匹配到’joint’的情况,确保过滤结果的准确性。文章提供了示例代码和使用注意事项,帮助开发者高效地筛选所需链接。

URL关键词匹配的挑战

在Python中处理URL列表时,我们经常需要根据URL中是否包含特定关键词来筛选链接。最直观的方法是使用Python的 in 操作符进行字符串包含判断,例如 if ‘join’ in link:。然而,这种方法存在一个显著的局限性:它会进行部分匹配。这意味着如果我们的关键词是 join,那么包含 joint、rejoin 等词的URL也会被匹配到,这往往不是我们期望的“精确匹配”。

例如,对于以下URL列表:

links = [    'https://enzymocore.com/news/august-2015-joint-venture-in-peru/',    'https://enzymocore.com/join-us']

如果关键词是 join,使用 in 操作符会同时匹配到这两个链接,因为第一个链接中的 joint 包含了 join。为了解决这个问题,我们需要一种更精确的匹配机制。

精确匹配的原理:引入正则表达式

Python的 re 模块提供了强大的正则表达式功能,能够实现复杂的字符串模式匹配。要实现关键词的精确匹配,核心思想是定义关键词的“边界”,确保匹配到的关键词是独立的词,而不是某个词的一部分。

立即学习“Python免费学习笔记(深入)”;

有两种常用的正则表达式模式可以实现这一目标:

使用非字母字符边界 [^a-zA-Z]使用词边界符 (推荐)

下面我们将分别介绍这两种实现方式。

实现方式一:非字母字符边界 [^a-zA-Z]

这种方法通过在关键词前后加上 [^a-zA-Z] 来限定其边界。[^a-zA-Z] 匹配任何非英文字母的字符。这意味着关键词的前后必须是非字母字符(例如空格、斜杠、连字符、数字或字符串的起始/结束),才能被视为一个独立的词。

模式解释:

[^a-zA-Z]:匹配任何不是小写字母a-z或大写字母A-Z的字符。(关键词):括号 () 用于捕获关键词,但在这里主要用于逻辑分组,可以匹配多个关键词。[^a-zA-Z]:再次确保关键词的右侧也是非字母字符。

示例代码:

import relinks = [    'https://enzymocore.com/news/august-2015-joint-venture-in-peru/',    'https://enzymocore.com/join-us',    'https://enzymocore.com/careers-info',    'https://enzymocore.com/career-path',    'https://enzymocore.com/our-join-page', # 额外测试用例    'https://enzymocore.com/2023-join-us'  # 额外测试用例]keywords = ['join', 'career']final_links_method1 = []print("--- 使用非字母字符边界 ([^a-zA-Z]) 匹配 ---")for link in links:    # 构建正则表达式,处理多个关键词。    # 注意:为了匹配字符串的开始或结束,我们可以在模式两端添加 (?:^|[^a-zA-Z]) 和 (?:$|[^a-zA-Z])    # 但对于URL路径中的常见情况,这种简化的模式通常足够,或者直接使用更优。    # 这里我们采用原始问题答案中的简化形式,并指出其局限性。    pattern_str = r"[^a-zA-Z](" + "|".join(keywords) + r")[^a-zA-Z]"    # 考虑关键词可能在链接的开头或结尾的情况,原始答案的模式可能无法匹配。    # 更完善的模式应该是: (?:^|[^a-zA-Z])(关键词)(?:$|[^a-zA-Z])    # 但为了贴合原始答案的思路,我们先展示其直接应用。    if re.search(pattern_str, link):        print(f"匹配到: {link}")        final_links_method1.append(link)    else:        # 如果关键词在链接的开头或结尾,且前后没有非字母字符,此模式可能不匹配。        # 此时需要特殊处理,或者直接使用 。        # 例如,对于 'https://enzymocore.com/join',如果用 [^a-zA-Z]join[^a-zA-Z] 无法匹配。        # 这里我们补充一个简单的检查,看关键词是否在链接的开头或结尾,以弥补 [^a-zA-Z] 的不足。        for kw in keywords:            if link.endswith('/' + kw) or link.endswith('-' + kw) or link.endswith('/' + kw + '/') or                link.startswith('https://enzymocore.com/' + kw) or                re.search(r"[^a-zA-Z]" + kw + r"$", link) or re.search(r"^" + kw + r"[^a-zA-Z]", link):                # 这是一个简化的补充逻辑,实际应用中建议使用                 if not any(l == link for l in final_links_method1): # 避免重复添加                    # print(f"补充匹配 (开头/结尾): {link} for {kw}")                    # final_links_method1.append(link) # 暂时不加,以免混淆主模式                    passprint(f"最终链接列表 (方法一): {final_links_method1}")

此方法的局限性:[^a-zA-Z] 模式无法直接匹配位于字符串开头或结尾的关键词,除非字符串开头或结尾本身被视为非字母字符。例如,对于 https://example.com/join,join 后面没有非字母字符,该模式将无法匹配。为了解决这个问题,通常会结合 ^ (字符串开头) 和 $ (字符串结尾) 锚点,形成更复杂的模式,如 (?:^|[^a-zA-Z])(join)(?:$|[^a-zA-Z])。

实现方式二:使用词边界符 (推荐)

是正则表达式中一个非常实用的特殊序列,它代表一个“词的边界”。词边界指的是一个词字符(字母、数字、下划线)和一个非词字符之间的位置,或者字符串的开头/结尾与一个词字符之间的位置。使用 能够更简洁、更准确地实现关键词的精确匹配,且能自动处理字符串开头和结尾的情况。

模式解释:

:匹配一个词的边界。(关键词):括号 () 用于分组,可以匹配多个关键词。:再次确保关键词的右侧也是一个词边界。

示例代码:

import relinks = [    'https://enzymocore.com/news/august-2015-joint-venture-in-peru/',    'https://enzymocore.com/join-us',    'https://enzymocore.com/careers-info',    'https://enzymocore.com/career-path',    'https://enzymocore.com/join_us_now',   # 测试  对下划线的处理    'https://enzymocore.com/2023-join-us', # 测试  对数字的处理    'https://enzymocore.com/join',         # 测试  对字符串结尾的处理    'https://enzymocore.com/join/',        # 测试  对斜杠的处理    'https://enzymocore.com/join.html'     # 测试  对点号的处理]keywords = ['join', 'career']final_links_method2 = []print("--- 使用词边界符 (b) 匹配 (推荐) ---")for link in links:    # 构建正则表达式,处理多个关键词    # re.escape() 用于转义关键词中可能存在的特殊字符    escaped_keywords = [re.escape(kw) for kw in keywords]    pattern_str = r"(" + "|".join(escaped_keywords) + r")"    # re.IGNORECASE 可以使匹配不区分大小写    if re.search(pattern_str, link, re.IGNORECASE):         print(f"匹配到: {link}")        final_links_method2.append(link)print(f"最终链接列表 (方法二): {final_links_method2}")

输出结果分析:使用 模式,joint 中的 join 不会被匹配,因为 t 是词字符,join 和 t 之间没有词边界。而 join-us、join_us_now、2023-join-us、join、join/、join.html 中的 join 都能被正确匹配,因为 -、_、数字、字符串结尾、/、. 都被视为词边界。这使得 成为实现精确关键词匹配的更优选择。

注意事项

URL结构与匹配位置: 正则表达式默认会在整个字符串中搜索匹配项。如果关键词可能出现在URL的不同部分(例如域名、路径、查询参数),上述模式都能有效。如果需要限定在URL的特定部分(例如只在路径中),则可能需要先解析URL。

大小写敏感性: 正则表达式默认是大小写敏感的。如果需要进行不区分大小写的匹配,可以在 re.search() 函数中添加 re.IGNORECASE 标志,如 re.search(pattern, link, re.IGNORECASE)。

URL编码 URL中可能包含百分号编码的字符(例如空格编码为 %20)。如果关键词可能以编码形式存在,可能需要先对URL进行解码(使用 urllib.parse.unquote)再进行匹配,或者调整正则表达式以匹配编码形式。

关键词列表处理: 当有多个关键词需要匹配时,可以使用 | 运算符将它们组合成一个正则表达式模式,如 (keyword1|keyword2|keyword3)。为了避免关键词本身包含正则表达式特殊字符导致错误,建议使用 re.escape() 对每个关键词进行转义。

性能考量: 对于处理大量URL的场景,预编译正则表达式可以提高性能。使用 re.compile() 将正则表达式模式编译成一个正则表达式对象,可以避免在循环中重复编译模式。

import re# ... (links 和 keywords 定义) ...escaped_keywords = [re.escape(kw) for kw in keywords]pattern_str = r"(" + "|".join(escaped_keywords) + r")"compiled_pattern = re.compile(pattern_str, re.IGNORECASE) # 预编译,并设置不区分大小写final_links_compiled = []for link in links:    if compiled_pattern.search(link):        final_links_compiled.append(link)print(f"最终链接列表 (预编译): {final_links_compiled}")

总结

在Python中进行URL关键词过滤时,为了避免 in 操作符带来的部分匹配问题,使用正则表达式是实现精确匹配的有效方法。其中,词边界符 提供了一种简洁而强大的机制,能够准确地识别URL中独立的关键词,并能很好地处理各种边界情况(如连字符、下划线、数字以及字符串的开头和结尾)。通过结合 re 模块、 词边界符以及适当的注意事项,开发者可以构建出高效、准确的URL筛选逻辑。

以上就是Python URL过滤:利用正则表达式实现关键词精确匹配的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1586458.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月23日 02:33:36
下一篇 2025年12月23日 02:33:52

相关推荐

  • 如何解决本地图片在使用 mask JS 库时出现的跨域错误?

    如何跨越localhost使用本地图片? 问题: 在本地使用mask js库时,引入本地图片会报跨域错误。 解决方案: 要解决此问题,需要使用本地服务器启动文件,以http或https协议访问图片,而不是使用file://协议。例如: python -m http.server 8000 然后,可以…

    2025年12月24日
    200
  • 使用 Mask 导入本地图片时,如何解决跨域问题?

    跨域疑难:如何解决 mask 引入本地图片产生的跨域问题? 在使用 mask 导入本地图片时,你可能会遇到令人沮丧的跨域错误。为什么会出现跨域问题呢?让我们深入了解一下: mask 框架假设你以 http(s) 协议加载你的 html 文件,而当使用 file:// 协议打开本地文件时,就会产生跨域…

    2025年12月24日
    200
  • 正则表达式在文本验证中的常见问题有哪些?

    正则表达式助力文本输入验证 在文本输入框的验证中,经常遇到需要限定输入内容的情况。例如,输入框只能输入整数,第一位可以为负号。对于不会使用正则表达式的人来说,这可能是个难题。下面我们将提供三种正则表达式,分别满足不同的验证要求。 1. 可选负号,任意数量数字 如果输入框中允许第一位为负号,后面可输入…

    2025年12月24日
    000
  • 为什么多年的经验让我选择全栈而不是平均栈

    在全栈和平均栈开发方面工作了 6 年多,我可以告诉您,虽然这两种方法都是流行且有效的方法,但它们满足不同的需求,并且有自己的优点和缺点。这两个堆栈都可以帮助您创建 Web 应用程序,但它们的实现方式却截然不同。如果您在两者之间难以选择,我希望我在两者之间的经验能给您一些有用的见解。 在这篇文章中,我…

    2025年12月24日
    000
  • 姜戈顺风

    本教程演示如何在新项目中从头开始配置 django 和 tailwindcss。 django 设置 创建一个名为 .venv 的新虚拟环境。 # windows$ python -m venv .venv$ .venvscriptsactivate.ps1(.venv) $# macos/linu…

    2025年12月24日
    000
  • 花 $o 学习这些编程语言或免费

    → Python → JavaScript → Java → C# → 红宝石 → 斯威夫特 → 科特林 → C++ → PHP → 出发 → R → 打字稿 []https://x.com/e_opore/status/1811567830594388315?t=_j4nncuiy2wfbm7ic…

    2025年12月24日
    000
  • 学会从头开始学习CSS,掌握制作基本网页框架的技巧

    从零开始学习CSS,掌握网页基本框架制作技巧 前言: 在现今互联网时代,网页设计和开发是一个非常重要的技能。而学习CSS(层叠样式表)是掌握网页设计的关键之一。CSS不仅可以为网页添加样式和布局,还可以为用户呈现独特且具有吸引力的页面效果。在本文中,我将为您介绍一些基本的CSS知识,以及一些常用的代…

    2025年12月24日
    200
  • 揭秘Web标准涵盖的语言:了解网页开发必备的语言范围

    在当今数字时代,互联网成为了人们生活中不可或缺的一部分。作为互联网的基本构成单位,网页承载着我们获取和分享信息的重要任务。而网页开发作为一门独特的技术,离不开一些必备的语言。本文将揭秘Web标准涵盖的语言,让我们一起了解网页开发所需的语言范围。 首先,HTML(HyperText Markup La…

    2025年12月24日
    000
  • 揭开Web开发的语言之谜:了解构建网页所需的语言有哪些?

    Web标准中的语言大揭秘:掌握网页开发所需的语言有哪些? 随着互联网的快速发展,网页开发已经成为人们重要的职业之一。而要成为一名优秀的网页开发者,掌握网页开发所需的语言是必不可少的。本文将为大家揭示Web标准中的语言大揭秘,介绍网页开发所需的主要语言。 HTML(超文本标记语言)HTML是网页开发的…

    2025年12月24日
    400
  • 常用的网页开发语言:了解Web标准的要点

    了解Web标准的语言要点:常见的哪些语言应用在网页开发中? 随着互联网的不断发展,网页已经成为人们获取信息和交流的重要途径。而要实现一个高质量、易用的网页,离不开一种被广泛接受的Web标准。Web标准的制定和应用,涉及到多种语言和技术,本文将介绍常见的几种语言在网页开发中的应用。 首先,HTML(H…

    2025年12月24日
    000
  • 网页开发中常见的Web标准语言有哪些?

    探索Web标准语言的世界:网页开发中常用的语言有哪些? 在现代社会中,互联网的普及程度越来越高,网页已成为人们获取资讯、娱乐、交流的重要途径。而网页的开发离不开各种编程语言的应用和支持。在这个虚拟世界的网络,有许多被广泛应用的标准化语言,用于为用户提供优质的网页体验。本文将探索网页开发中常用的语言,…

    2025年12月24日
    000
  • 深入探究Web标准语言的范围,涵盖了哪些语言?

    Web标准是指互联网上的各个网页所需遵循的一系列规范,确保网页在不同的浏览器和设备上能够正确地显示和运行。这些标准包括HTML、CSS和JavaScript等语言。本文将深入解析Web标准涵盖的语言范围。 首先,HTML(HyperText Markup Language)是构建网页的基础语言。它使…

    2025年12月24日
    000
  • CSS 超链接属性解析:text-decoration 和 color

    CSS 超链接属性解析:text-decoration 和 color 超链接是网页中常用的元素之一,它能够在不同页面之间建立连接。为了使超链接在页面中有明显的标识和吸引力,CSS 提供了一些属性来调整超链接的样式。本文将重点介绍 text-decoration 和 color 这两个与超链接相关的…

    2025年12月24日
    000
  • 看看这些前端面试题,带你搞定高频知识点(一)

    每天10道题,100天后,搞定所有前端面试的高频知识点,加油!!!,在看文章的同时,希望不要直接看答案,先思考一下自己会不会,如果会,自己的答案是什么?想过之后再与答案比对,是不是会更好一点,当然如果你有比我更好的答案,欢迎评论区留言,一起探讨技术之美。 面试官:给定一个元素,如何实现水平垂直居中?…

    2025年12月24日 好文分享
    300
  • 看看这些前端面试题,带你搞定高频知识点(二)

    每天10道题,100天后,搞定所有前端面试的高频知识点,加油!!!,在看文章的同时,希望不要直接看答案,先思考一下自己会不会,如果会,自己的答案是什么?想过之后再与答案比对,是不是会更好一点,当然如果你有比我更好的答案,欢迎评论区留言,一起探讨技术之美。 面试官:页面导入样式时,使用 link 和 …

    2025年12月24日 好文分享
    200
  • 看看这些前端面试题,带你搞定高频知识点(三)

    每天10道题,100天后,搞定所有前端面试的高频知识点,加油!!!,在看文章的同时,希望不要直接看答案,先思考一下自己会不会,如果会,自己的答案是什么?想过之后再与答案比对,是不是会更好一点,当然如果你有比我更好的答案,欢迎评论区留言,一起探讨技术之美。 面试官:清除浮动有哪些方式? 我:呃~,浮动…

    2025年12月24日 好文分享
    000
  • 看看这些前端面试题,带你搞定高频知识点(四)

    每天10道题,100天后,搞定所有前端面试的高频知识点,加油!!!,在看文章的同时,希望不要直接看答案,先思考一下自己会不会,如果会,自己的答案是什么?想过之后再与答案比对,是不是会更好一点,当然如果你有比我更好的答案,欢迎评论区留言,一起探讨技术之美。 面试官:请你谈一下自适应(适配)的方案 我:…

    2025年12月24日 好文分享
    000
  • 看看这些前端面试题,带你搞定高频知识点(五)

    每天10道题,100天后,搞定所有前端面试的高频知识点,加油!!!,在看文章的同时,希望不要直接看答案,先思考一下自己会不会,如果会,自己的答案是什么?想过之后再与答案比对,是不是会更好一点,当然如果你有比我更好的答案,欢迎评论区留言,一起探讨技术之美。 面试官:css 如何实现左侧固定 300px…

    2025年12月24日 好文分享
    000
  • HTML+CSS+JS实现雪花飘扬(代码分享)

    使用html+css+js如何实现下雪特效?下面本篇文章给大家分享一个html+css+js实现雪花飘扬的示例,希望对大家有所帮助。 很多南方的小伙伴可能没怎么见过或者从来没见过下雪,今天我给大家带来一个小Demo,模拟了下雪场景,首先让我们看一下运行效果 可以点击看看在线运行:http://hai…

    2025年12月24日 好文分享
    500
  • 分享20个首页流行布局样式,总有一款适合你!

    本篇文章给大家分享20个首页流行布局样式,总有一款适合你,快来收藏试试吧,希望对大家有所帮助! 有时我们会在网站上遇到一些内容布局问题,如文字对齐、图片设计与内容和谐、为文章选择合适的字体……在今天的文章中,介绍一些设计精美的创意布局,let‘s  开始。 代号 001 源码…

    2025年12月24日 好文分享
    000

发表回复

登录后才能评论
关注微信