当前位置: 首页 > news >正文

文本处理:字符串替换

方法1:str.replace

str.replace(old, new[, count])
Return a copy of the string with all occurrences of substring old replaced by new. If the optional argument count is given, only the first count occurrences are replaced.

该方法逻辑大致如下所示,存在多个 oldnew 映射对时,需要串联使用多个 replace 方法, 效率较低。

matches = list(re.finditer(old, string))if len(matches) == 0:returnif count > 0:for match in matches:string[match.start(0): match.end(0)] = match.group(0)count -= 1if count == 0:break
else:for match in matches:string[match.start(0): match.end(0)] = match.group(0)

 

方法2:str.translate

在了解该方法之前,先了解类方法 str.maketrans

str.maketrans(x[, y[, z]])

  • If there is only one argument, it must be a dictionary mapping Unicode ordinals (integers) or characters (strings of length 1) to Unicode ordinals, strings (of arbitrary lengths) or None. Character keys will then be converted to ordinals.
  • If there are two arguments, they must be strings of equal length, and in the resulting dictionary, each character in x will be mapped to the character at the same position in y. If there is a third argument, it must be a string, whose characters will be mapped to None in the result.
  • 如果实参值是一个字典,则字典的键可以为“单个字符”、“Unicode 序数”, 字典值可以为“Unicode 序数”、“任意长度的字符串”、None。返回结果为一个字典,返回字典的键会转换为“Unicode 序数”, 返回字典的值与实参值一致。

  • 如果传入两个实参值,则位置参数xy 必须是一个任意长度的字符串,会将同一位置的x字符映射为y 字符,如果存在第三个实参值,位置参数z 中的每一个字符将与 None 建立映射关系:

    assert len(x) == len(y)d = dict()
    for c_x, c_y in zip(x, y):d.update({ord(c_x): c_y}if z is not None:for c_z in z:d.update({ord(c_z}: None)
    

str.translate(table)
Return a copy of the string in which each character has been mapped through the given translation table.

位置参数table 接受的实参值类似于 str.maketrans 的返回结果,str.translate 会将字符串一一进行映射,如果字符对应的 Unicode 序数在实参值字典中,则可能会被映射为其它任意长度的字符串,或者被删除(Unicode 序数对应 None 时)。
 

方法3:re.sub(比较复杂)

re.sub(pattern, repl, string, count=0, flags=0)
Return the string obtained by replacing the leftmost non-overlapping occurrences of pattern in string by the replacement repl.

此函数的逻辑大致如下:

matches = list(re.finditer(pattern, string))if len(matches) == 0:  # If the pattern isn’t found, string is returned unchanged.return string
else:for match in matches:if isinstance(repl, str):  # repl can be a string or a functionstring[match.start(0): match.end(0)] = replelse:string[match.start(0): match.end(0)] = repl(match)return string

从左往右,将string 中匹配到pattern并且非重叠的部分替换成replrepl 可以是一个字符串,也可以是一个函数。

“非重叠”的意思是指 patternstring匹配的部分不存在重叠情况,如下:pattern 第一次匹配 string中的 “12”, 第二次匹配 string中的 “34”, 而非“23”,否则相邻的两个匹配存在重叠。

re.sub(r"(\d)(\d)", "99", "1234")  # return "9999"

repl 为字符串类型时,支持“转义”与组内容的反向引用,即会对repl 中转义的部分进行特殊处理, 注意包含转义符号\ 时,需使用 Python Raw String 表示法

  • 转义 ASCII 字符,并且是有效转义,替换后的结果采用转义后的字符,如 “\n” 表示一个换行符。

    re.sub(r"(\d)(\d)", r"a\nb", "1234")   # return 'a\nba\nb'
    
  • 如果转义 ASCII 失败,则抛出异常:

    re.sub(r"(\d)(\d)", r"\z", "1234")  # 抛出异常 re.error: bad escape \z at position 0
    
  • 如果与其它非 ASCII 转义,不做处理,仅保留非 ASCII 字符:

    re.sub(r"(\d)(\d)", r"\&", "1234")   # return '\\&\\&'
    
  • 如果转义符号与组编号组合,则引用第编号组匹配到的内容:

    re.sub(r"(\d)(\d)", r"\1", "1234")  # return "13# 如果第二项为 "\1", 则返回'\x01\x01'————双重转义,Python 与 正则表达式都将 “\” 作为转义字符。
    # ord("\x01") -> 1
    # chr(1) -> "\x01"
    
  • 在 Python 3.9 中,除了支持组编号,也支持组别名,来引用特定组匹配到的内容,只是此种情形中,需在 pattern 中为组进行命名 :

    re.sub(r"(?P<group1>\d)(?P<group2>\d)", r"\<group1>", "1234")  # 使用组名 “13”
    re.sub(r"(?P<group1>\d)(?P<group2>\d)", r"\<1>", "1234")  # 使用组编号 “13”
    

如果 repl 为函数, 则传入实参为 re.Match,函数返回值需为字符串, 如下:

def func(match):if len(match.group(0)) > 1:return "9" * len(match.group(0))else:return ""re.sub(r"\d+", func, "a1b23c456")  # return "ab99c999"

相关文章:

文本处理:字符串替换

方法1&#xff1a;str.replace str.replace(old, new[, count]) Return a copy of the string with all occurrences of substring old replaced by new. If the optional argument count is given, only the first count occurrences are replaced. 该方法逻辑大致如下所示&am…...

python 调用 dll 出现精度问题

问题&#xff1a;python 在调用dll 的时候出现了精度问题 总结&#xff1a;使用decimal库进行转换就可以正常传递。 ‘ 心急的朋友可以略过下文了。 心急的朋友可以略过下文了。 心急的朋友可以略过下文了。 心急的朋友可以略过下文了。 ’ 遇到的问题具体情况 dll 生成函数…...

STL讲解——模拟实现string

STL讲解——模拟实现string 经典的string类问题 大厂在面试中&#xff0c;面试官总喜欢让学生自己来模拟实现string类&#xff0c;最主要是实现string类的增、删、查、改、构造、拷贝构造、赋值运算符重载以及析构函数。大家看下自己可不可以写一个string类&#xff1f; cla…...

CDH 6.3.2 升级Hive 2.3.9

升级背景 DolphinScheduler 3.1.1安装好后&#xff0c;其源码中集成的是Hive 2.1.1&#xff0c;版本太低&#xff0c;当在数据中心连接Hive数据源时报错&#xff0c;所以升级CDH自带的Hive为2.3.9版本。 一、准备工作 1、下载hive2.3.9并解压 下载地址&#xff1a;http://a…...

距离不是拦截我们前进的主因,与社科院杜兰金融硕士一起奔赴山海

最近有咨询社科院杜兰金融管理硕士项目的同学反馈他在西安&#xff0c;读研来北京上课太远了。一直在纠结要不要申请&#xff0c;其实距离不是问题&#xff0c;相向而行才是关键。在项目就读的同学好多也是来自外地&#xff0c;他们克服了种种困难来到项目学习&#xff0c;就是…...

【SpringBoot】MyBatis-plus 报错 sqlSessionFactory sqlSessionTemplate 最新解决办法

本文针对 MyBatis-plus&#xff0c;对于 MyBatis 报相同的错误&#xff0c;可以看这个大佬的文章&#xff1a;SpringBoot3整合MyBatis报错&#xff1a;Property ‘sqlSessionFactory‘ or ‘sqlSessionTemplate‘ are required 针对报错如下&#xff1a; Property sqlSessionF…...

jsp诊疗预约系统Myeclipse开发mysql数据库web结构java编程计算机网页项目

一、源码特点 jsp诊疗预约系统 是一套完善的web设计系统&#xff0c;对理解JSP java编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模式开发。开发环境为TOMCAT7.0,Myeclipse8.5开发&#xff0c;数据库为Mysql&#xff0c;使用jav…...

详解 APISIX Lua 动态调试插件 inspect

作者罗锦华&#xff0c;API7.ai 技术专家/技术工程师&#xff0c;开源项目 pgcat&#xff0c;lua-resty-ffi&#xff0c;lua-resty-inspect 的作者。 原文链接 为什么需要 Lua 动态调试插件&#xff1f; Apache APISIX 有很多 Lua 代码&#xff0c;如何在运行时不触碰源代码的…...

#科研筑基# python初学自用笔记 第五篇 函数

调用函数python有很多内置函数&#xff0c;我们可以直接调用&#xff0c;详见python官方文档&#xff1a;内置函数 — Python 3.11.2 文档&#xff0c;也可以在命令行中输入help(函数名)来查看该函数的使用法则。函数名的本质就是指向一个函数对象的引用&#xff0c;完全可以用…...

设计模式之策略模式

一.基本内容1 . 实例有各种鸭子&#xff08;野鸭&#xff0c;北京鸭子&#xff0c;水鸭等&#xff0c;鸭子有各种行为&#xff0c;比如飞&#xff0c;叫等显示鸭子的信息传统方法解决&#xff1a;鸭子为抽象类&#xff0c;具体鸭子继承抽象类2.传统方法的不足&#xff1a;其他鸭…...

dbdeployer 使用札记

https://github.com/datacharmer/dbdeployer默认配置文件为当前用户的$HOME/.dbdeployer/config.json作为配置文件&#xff0c;可以通过dbdeplyoer defaults export导出并修改配置或者直接通过dbdeployer defaults update来更新默认文件&#xff0c;配置文件包含MySQL初始信息。…...

MATLAB算法实战应用案例精讲-【图像处理】数字图像模糊化(附Java、python和matlab代码实现)

目录 前言 几个相关概念 噪声 滤波器 算法原理 算法思想 噪...

搭建Hexo博客-第1章-Git和GitHub以及Coding的简单用法

搭建Hexo博客-第1章-Git和GitHub以及Coding的简单用法 搭建Hexo博客-第1章-Git和GitHub以及Coding的简单用法 Coding GitHub Hexo Markdown 搭建博客 大家好&#xff0c;这是我第一次写博客。使用 GitHub Hexo 创建最基本的博客很容易&#xff0c;网上有很多现成的教程。…...

【C++修行之路】C/C++内存管理

文章目录程序区域内存划分C语言动态内存分配&#xff1a;new和delete&#xff1a;new、delete和malloc、free的区别:程序区域内存划分 C/C程序内存区域划分非常相似。 C语言动态内存分配&#xff1a; malloc、calloc、realloc都是C语言动态开辟内存的常用函数 其中 malloc 开…...

spring cloud alibaba Sentinel(四)

服务雪崩 在分布式系统中,由于网络原因或自身的原因,服务一般无法保证 100% 可用。 如果一个服务出现了问题&#xff0c;调用这个服务就会出现线程阻塞的情况&#xff0c; 此时若有大量的请求涌入&#xff0c;就会出现多条 线程阻塞等待&#xff0c;进而导致服务瘫痪。 由于服…...

Redis第三讲

目录 三、Redis03 3.1 Redis持久化之RDB 3.1.1 什么是RDB 3.1.2 备份是如何执行的 3.1.3 Fork 3.1.4 RDB持久化流程 3.1.5 dump.rdb文件 3.1.6 配置rdb文件生成位置 3.1.7 如何触发RDB快照以及保持策略 3.2 Redis持久化之AOF 3.2.1 什么是AOF 3.2.2 AOF持久化流程 …...

JAVA线程池的使用

一、池化思想和JAVA线程池 池化是很重要的思想&#xff1b;池化的好处是提供缓冲和统一的管理。这个笔者在本人的数据库连接池的博客中已经提到过了&#xff08;JAVA常用数据库连接池_王者之路001的博客-CSDN博客 &#xff09;。 线程池是另一种池化思想的运用&#xff0c;把…...

力扣56.合并区间

文章目录力扣56.合并区间题目描述排序合并力扣56.合并区间 题目描述 以数组 intervals 表示若干个区间的集合&#xff0c;其中单个区间为 intervals[i] [starti, endi] 。请你合并所有重叠的区间&#xff0c;并返回 一个不重叠的区间数组&#xff0c;该数组需恰好覆盖输入中…...

代码随想录二刷Day03链表: 24.两两交换链表中的节点,19.删除链表的倒数第N个节点,面试题 02.07. 链表相交,142.环形链表||

24.两两交换链表中的节点 文章链接&#xff1a;代码随想录 (programmercarl.com) 思路&#xff1a; &#xff08;1&#xff09;首先如果要处理相邻两个节点的话&#xff0c;一定需要操作两个节点的前一个节点才可以&#xff0c;因此&#xff0c;本题需要设定一个虚拟头节点 …...

我应该在我的博客上写什么? 介绍如何撰写初学者容易担心的文章

我想有很多人开了博客&#xff0c;但想不起来写作&#xff0c;无法取得进展。 博客的主题和文章的内容不会仅仅通过写你想做的事情来工作。 重要的是要了解用户想要阅读的内容以及人们可能收集的内容&#xff0c;并将其与您想要编写的内容很好地匹配。 这一次&#xff0c;我…...

如何快速集成KYGooeyMenu:iOS粘液菜单的完整实现指南

如何快速集成KYGooeyMenu&#xff1a;iOS粘液菜单的完整实现指南 【免费下载链接】KYGooeyMenu A not bad gooey effects menu. 项目地址: https://gitcode.com/gh_mirrors/ky/KYGooeyMenu KYGooeyMenu是一款为iOS应用打造的粘液效果菜单组件&#xff0c;能为你的应用添…...

5分钟极速上手:用BepInEx打造你的专属游戏世界

5分钟极速上手&#xff1a;用BepInEx打造你的专属游戏世界 【免费下载链接】BepInEx Unity / XNA game patcher and plugin framework 项目地址: https://gitcode.com/GitHub_Trending/be/BepInEx 想象一下&#xff0c;你刚入手了一款心仪已久的游戏&#xff0c;但总觉得…...

MCGS触摸屏Modbus通讯调试避坑指南:从驱动安装到脚本调试的全流程解析

MCGS触摸屏Modbus通讯调试避坑指南&#xff1a;从驱动安装到脚本调试的全流程解析 第一次接触MCGS触摸屏与Modbus通讯集成的工程师&#xff0c;往往会在调试过程中遇到各种"坑"。本文将从实际项目经验出发&#xff0c;梳理从驱动安装到脚本调试的全流程中那些容易踩雷…...

8086/8088单板机VSCode集中环境开发编译(第二版整理)

对于8086/8088单板机而言&#xff0c;集中的开发环境方便友好。下面是使用VSCode集中开发环境对8086/8088单板机集中编辑、编译、串口下载的使用步骤第一步&#xff0c;在VSCode文件中&#xff0c;选择打开例程文件夹第二部&#xff0c;根据需要对例程main.c进行编辑修改第三步…...

ShareGPT4Omni/ShareGPT4Video:构建可分享的AI对话知识库实战指南

1. 项目概述&#xff1a;当AI多模态模型遇上“分享”的刚需 最近在AI圈子里&#xff0c;一个现象级的开源项目“ShareGPT4Omni/ShareGPT4Video”引起了我的注意。乍一看标题&#xff0c;你可能以为这又是一个基于GPT-4的对话应用&#xff0c;但它的核心价值远不止于此。简单来说…...

CANN Ascend C uint32转bfloat16函数

__uint2bfloat16_rd 【免费下载链接】asc-devkit 本项目是CANN 推出的昇腾AI处理器专用的算子程序开发语言&#xff0c;原生支持C和C标准规范&#xff0c;主要由类库和语言扩展层构成&#xff0c;提供多层级API&#xff0c;满足多维场景算子开发诉求。 项目地址: https://git…...

混合量子-经典工作流编排的云原生实践

1. 混合量子-经典工作流编排的挑战与机遇量子计算正从实验室走向实际应用&#xff0c;但当前NISQ&#xff08;Noisy Intermediate-Scale Quantum&#xff09;时代的量子设备仍面临量子比特数量有限、噪声干扰强等限制。这使得混合量子-经典工作流&#xff08;Hybrid Quantum–C…...

从mekong-cli看现代CLI工具的设计哲学与工程实践

1. 项目概述&#xff1a;一个命令行工具能做什么&#xff1f;在开发者的日常工作中&#xff0c;命令行界面&#xff08;CLI&#xff09;是我们与计算机系统交互最直接、最高效的桥梁。无论是自动化部署、批量处理文件&#xff0c;还是与远程API进行交互&#xff0c;一个设计精良…...

极简终端AI聊天工具gptcli:单文件Python脚本实现OpenAI API兼容客户端

1. 项目概述&#xff1a;一个极简的终端AI聊天工具如果你和我一样&#xff0c;经常需要在终端里和AI模型对话&#xff0c;但又觉得官方网页版太重、第三方客户端功能太杂&#xff0c;那么这个项目可能就是你的菜。gptcli是一个用单个Python脚本实现的、功能纯粹的终端聊天客户端…...

忆阻器神经形态计算与模块化建模技术解析

1. 忆阻器与神经形态计算基础忆阻器&#xff08;Memristor&#xff09;作为继电阻、电容、电感之后的第四种基本电路元件&#xff0c;其核心特性在于阻值会"记忆"过往通过的电荷量。这种记忆特性源于器件内部的可逆物理变化&#xff0c;例如离子迁移、氧空位形成或聚…...