Python 优雅编程:会报恩的代码(五)

文章目录

    • 引言
    • 从文本搜索指定单词,不区分单词的大小写
      • 使用 `str.lower()`
      • 使用 `re` 模块
    • 从文本搜索多个单词,依旧不区分单词的大小写
      • 使用 `str.lower()` 和循环
      • 使用 `re` 模块
    • 反复执行 re.compile,re 是否会缓存编译结果?
    • 结语

引言

在 Python 编程中,有一些常用技巧和最佳实践可以帮助你编写更优雅、更高效的代码。本文将介绍的是使用 Python 从文本中搜索指定单词的几个简单实现方式。

在这里插入图片描述

从文本搜索指定单词,不区分单词的大小写

我们可以使用 Python 的内置字符串方法以及正则表达式来搜索文本中的指定单词,且不区分大小写。

使用 str.lower()

如果希望使用简单的字符串方法,可以将文本和目标单词都转换为小写,然后进行比较:

def search_word(text, word):# 转换为小写text_lower = text.lower()word_lower = word.lower()# 检查单词是否在文本中if word_lower in text_lower:return Truereturn False# 示例
text = "Hello, this is a sample Text."
word = "text"
found = search_word(text, word)
print(found)  # 输出: True

使用 re 模块

如果想使用正则表达式,可以用 re 模块的 re.IGNORECASE 选项:

import redef search_word(text, word):# 使用正则表达式不区分大小写pattern = re.compile(re.escape(word), re.IGNORECASE)return bool(pattern.search(text))# 示例
text = "Hello, this is a sample Text."
word = "text"
found = search_word(text, word)
print(found)  # 输出: True

这两种方法都可以有效地搜索文本中的指定单词,且不区分大小写。选择适合需求的方法即可。

从文本搜索多个单词,依旧不区分单词的大小写

如果希望在文本中搜索多个单词,可以扩展前面的示例。

使用 str.lower() 和循环

可以将多个单词转换为小写并逐个检查:

def search_words(text, words):# 转换为小写text_lower = text.lower()words_lower = [word.lower() for word in words]# 检查每个单词是否在文本中found_words = [word for word in words_lower if word in text_lower]return found_words# 示例
text = "Hello, this is a sample Text."
words = ["text", "hello", "sample", "world"]
found = search_words(text, words)
print(found)  # 输出: ['text', 'hello', 'sample']

使用 re 模块

使用正则表达式可以创建一个模式,匹配多个单词:

import redef search_words(text, words):# 创建正则表达式模式pattern = re.compile(r'\b(?:' + '|'.join(map(re.escape, words)) + r')\b', re.IGNORECASE)# 搜索所有匹配的单词return pattern.findall(text)# 示例
text = "Hello, this is a sample Text."
words = ["text", "hello", "sample", "world"]
found = search_words(text, words)
print(found)  # 输出: ['Hello', 'Text', 'sample']

其中的正则表达式的作用是将多个单词组合成一个正则模式。确保这些单词作为独立的整词出现(通过使用单词边界)。在搜索时不区分大小写。

例如,如果 words 列表包含 ["cat", "dog"],则编译后的 pattern 表达式将类似于:

r'\b(?:cat|dog)\b'

这样,这个模式就可以匹配文本中的“cat”或“dog”,并且这些单词必须是独立的,不是其他词的一部分。

这段正则表达式用于编译一个模式,以匹配多个指定单词。表达式每个部分的详细解释如下。

r'\b(?:...)\b'

  • r'...': 这是一个原始字符串(raw string),它告诉 Python 不要对字符串中的反斜杠进行转义处理。这在> 编写正则表达式时非常有用,因为正则中的很多模式都包含反斜杠。

  • \b: 这是一个单词边界(word boundary)匹配符。它匹配单词的开始或结束位置,确保匹配的单词是完整的,> 而不是长词的一部分。例如,在匹配“cat”时,\bcat\b只会匹配“cat”这个词,而不会匹配“category”中的“cat”。

  • (?:...): 这是一个非捕获分组(non-capturing group)。它的作用是将多个元素组合在一起,但不创建一个> 捕获组。这样可以在正则表达式中将多个选项组合在一起,而不会增加额外的捕获组。

|(或操作符)

  • '|'.join(map(re.escape, words)): 这段代码会将 words 列表中的所有单词通过 |(或操作符)连接> 成一个长字符串。map(re.escape, words) 用于处理 words 列表中每个单词,确保特殊字符不会影响正则表达式> 的匹配。例如,如果单词中有点号、星号等特殊字符,re.escape 会在这些字符前添加反斜杠,使其被视为字面字符。

re.IGNORECASE

  • 这是一个标志,表示匹配时不区分大小写。当这个标志被设置,正则表达式的匹配会忽略字母的大小写。

以上两种方法都可以有效地搜索文本中的多个指定单词。可以根据需求选择适合的方法。第一种方法直接使用字符串方法,第二种方法则利用正则表达式提供了更强大的功能。

反复执行 re.compile,re 是否会缓存编译结果?

Python 的 re 模块是会缓存编译的正则表达式的。这个缓存机制可以有效提高性能,避免对同一模式的重复编译。

缓存机制

当使用 re.compile() 编译一个正则表达式时,Python 会创建一个正则表达式对象,并在内部进行一些优化。

re 模块会在内部缓存最近使用的正则表达式。具体来说,Python 会保留最后 1000 个不同的模式,以供后续的重复使用。如果在同一程序运行中多次使用 re.compile() 编译相同的模式,Python 会直接返回缓存中的已经编译的对象而不是重复编译。

性能提升

缓存机制的作用明显,正则表达式的编译是一个相对昂贵的操作。通过避免重复编译,可以显著提高代码的运行效率。

最佳实践

如果在多个不同的字典或列表中使用相同的正则表达式模式,并在此过程中调用 re.compile(),那么如果模式相同,Python 会利用缓存。但是,为了保证最佳性能,尤其在频繁使用的情况下,建议将相同的正则表达式编译一次并存储在变量中,而不是每次都调用 re.compile()

验证示例

# 多次使用相同的正则表达式
pattern1 = re.compile(r'\bcat\b', re.IGNORECASE)
pattern2 = re.compile(r'\bcat\b', re.IGNORECASE)# pattern1 和 pattern2 是相同的模式
print(pattern1 is pattern2)  # 输出可能为 False,但模式是相同的
# True

在处理不同单词集合时,建议在循环外部编译正则模式,确保良好的性能并充分利用缓存特性。

结语

本文介绍了使用 Python 从文本中搜索指定单词的几个特定用法,并验证了 re.compile 中缓存的存在,希望这些小技巧能在某个特定的时间正好帮到你。


PS:感谢每一位志同道合者的阅读,欢迎关注、点赞、评论!


  • 上一篇:Python 优雅编程:会报恩的代码(四)
  • 专栏:「计算通践」

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/417863.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

day47——面向对象特征之继承

一、继承(inhert) 面向对象三大特征:封装、继承、多态 继承:所谓继承,是类与类之间的关系。就是基于一个已有的类,来创建出一个新类的过程叫做继承。主要提高代码的复用性。 1.1 继承的作用 1> 实现…

【一嗨租车-注册安全分析报告-滑动验证加载不正常导致安全隐患】

前言 由于网站注册入口容易被黑客攻击,存在如下安全问题: 暴力破解密码,造成用户信息泄露短信盗刷的安全问题,影响业务及导致用户投诉带来经济损失,尤其是后付费客户,风险巨大,造成亏损无底洞…

UE4_后期处理_后期处理材质及后期处理体积三—遮挡物体描边显示

一、效果: 在很多游戏中为了玩家能看到墙面背后是否有敌人,会给被遮挡的敌人增加描边显示,效果如下: 参考: https://zhuanlan.zhihu.com/p/81310476 https://zhuanlan.zhihu.com/p/358140547 二、所需知识 知识点…

Java笔试面试题AI答之JDBC(3)

文章目录 13. 编写JDBC连Oracle的程序?14. 简述JDBC的主要组件有哪些 ?15. JDBC中如何防止SQL注入攻击?1. 使用预处理语句(PreparedStatement)2. 避免在SQL查询中直接拼接用户输入的数据总结 16. JDBC的脏读是什么?哪…

Spring01——Spring简介、Spring Framework架构、Spring核心概念、IOC入门案例、DI入门案例

为什么要学 spring技术是JavaEE开发必备技能,企业开发技术选型命中率>90%专业角度 简化开发:降低企业开发的复杂度框架整合:高效整合其他技术,提高开发与运行效率 学什么 简化开发 IOCAOP 事务处理 框架整合 MyBatis 怎…

深度学习的基础_多层感知机的手动实现

多层感知机(Multilayer Perceptron,简称MLP)是一种前馈人工神经网络。它包含至少三层节点:一个输入层、一个或多个隐藏层以及一个输出层。除输入节点外,每个节点都是一个带有非线性激活函数的神经元(或称为…

Word快速重复上一步操作的三种高效方法

在日常工作、学习和生活中,我们经常需要执行一系列重复性的操作。这些操作可能简单如复制粘贴、调整图片大小,也可能复杂如编辑文档、处理数据等。为了提高效率,掌握快速重复上一步操作的方法显得尤为重要。本文将介绍三种高效的方法&#xf…

给力!Python配置文件,这一篇就够了!

在开发过程中,我们常常会用到一些固定参数或者是常量。对于这些较为固定且常用到的部分,往往会将其写到一个固定文件中,避免在不同的模块代码中重复出现从而保持核心代码整洁。 这里插播一条粉丝福利,如果你在学习Python或者有计划…

【C题成品论文已出】24数学建模国赛C题成品论文(附参考代码)免费分享

24高教社杯数学建模国赛C题成品论文 一、问题一模型建立与求解 1.1模型建立 (1)决策变量设计 表示一个26158的矩阵,其中26是平旱地梯田和山坡地的总数,15是在这几类土地上可以种植的农作物数量,8则表示从2023到203…

KCP实现原理探析

KCP 是一个轻量级的、高效的、面向 UDP 的传输协议库,专为需要低延迟和高可靠性的实时应用设计。本文针对 KCP 的主要机制和实现与原理进行分析。 1. 术语 术语 全称 说明 TCP Transmission Control Protocol 传输控制协议 RTT Round Trip Time 往返时延 …

【鸿蒙HarmonyOS NEXT】调用后台接口及List组件渲染

【鸿蒙HarmonyOS NEXT】调用后台接口及List组件渲染 一、环境说明二、调用后台接口及List组件渲染三、总结 一、环境说明 DevEco Studio 版本: API版本:以12为主 二、调用后台接口及List组件渲染 后台接口及返回数据分析 JSON数据格式如下&#xf…

Git创建项目

方法一 1.在gitee中新建仓库demo01,并勾选开源许可证,完成后gitee上面的项目demo01里只包含一个LICENSE文件 2.直接在本地电脑中新建项目文件夹demo01,双击进入这个文件夹,右键Git bash here,输入 git clone https:…

跨域问题(CORS)

文章目录 介绍解决一、添加跨域头,允许跨域1.后端配置CORS策略(4种方法)2.配置nginx 二、代理 介绍 跨域资源共享(CORS, Cross-Origin Resource Sharing)是浏览器的一个安全机制,用来防止来自一个域的网页对另一个域下的资源进行…

Linux操作系统在虚拟机VM上的安装【CentOS版本】

目录 准备工作 "CPU虚拟化"的方法 VMware的安装 Linux镜像文件的下载 开始安装 声明 新建虚拟机 安装CentOS7.6 配置Linux(CentOS7.6)操作系统 配置分区【学习者可以直接点击自动配置分区,不过还是建议学习一下手动分区】 分区原则 添加分区 …

提示工程颠覆:DSPy 引领全新范式革命

几个月前,我清楚地记得,Prompt Engineering 还是热门话题。就业市场上充斥着提示工程师的岗位,仿佛这是未来的必备技能。 然而,现在情况已经大不相同了。提示工程并不是一门艺术或科学,更像是“聪明的汉斯”现象——人类为系统提供了必要的背景,以便系统能更好地作出回应…

Maven聚合与继承

聚合 当我们一次想要构建多个项目时,而不是到每一个模块的目录下分别执行mvn命令。这个时候就需要使用到maven的聚合特性 这里第一个特殊的地方是packaging,值设置为pom。我们正常开发的其他模块中都没有声明packaging,默认使用了默认值jar&a…

【Qt】仿照qq界面的设计

widget.h #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QDebug>//QT中信息调试类&#xff0c;用于输出数据&#xff0c;无需使用该类的实例化对象&#xff0c;直接使用成员函数即可 #include <QIcon>//图标类 #include <QPushButton&…

代码随想录——回文子串(Leetcode 647)

题目链接 我的题解&#xff08;双指针&#xff09; 思路&#xff1a; 当然&#xff0c;以下是对您提供的代码的解释&#xff1a; class Solution {public int countSubstrings(String s) {// 初始化回文子字符串的数量int count 0;// 遍历字符串的每个字符&#xff0c;使用…

综合评价 | 基于熵权-变异系数-博弈组合法的综合评价模型(Matlab)

目录 效果一览基本介绍程序设计参考资料 效果一览 基本介绍 根据信息熵的定义&#xff0c;对于某项指标&#xff0c;可以用熵值来判断某个指标的离散程度&#xff0c;其信息熵值越小&#xff0c;指标的离散程度越大&#xff0c; 该指标对综合评价的影响&#xff08;即权重&…

基于鸿道Intewell操作系统的运动控制系统方案

随着工业控制行业的蓬勃发展&#xff0c;操作系统实时与非实时业务的深度融合应用需求日益增长&#xff0c;特别是在Windows或Linux平台上处理机器视觉等复杂场景时&#xff0c;传统实时操作系统&#xff08;RTOS&#xff09;面临显著挑战。这些挑战主要体现在两方面&#xff1…