【Python 千题 —— 算法篇】字符串替换

news2024/9/20 10:42:43

请添加图片描述

Python 千题持续更新中 ……
脑图地址 👉:⭐https://twilight-fanyi.gitee.io/mind-map/Python千题.html⭐

字符串处理

题目背景

在日常编程中,我们经常会遇到需要对字符串中的特定字符或子串进行替换的需求。比如,替换文本中的敏感词汇、修改文本中的标记符号、修正输入中的错误字符等。字符串替换在文本处理、数据清洗、格式转换等任务中非常常见。

了解并掌握多种字符串替换方法,不仅可以提高代码的可读性和效率,还能更灵活地处理复杂的文本操作需求。本篇将介绍几种常见的字符串替换方法,并讨论它们的优缺点。

题目描述

编写一个函数 replace_substring(),该函数接收三个参数:一个目标字符串 s,一个子串 old_sub,以及一个替换子串 new_sub。要求将目标字符串中所有出现的 old_sub 替换为 new_sub,并返回替换后的新字符串。

函数需满足以下要求:

  1. 定义一个函数 replace_substring(s, old_sub, new_sub),返回替换后的字符串。

    • 输入为空字符串时,返回空字符串。
    • 输入 old_sub 不存在于字符串中时,返回原字符串。
  2. 实现至少三种不同的替换方法,并讨论每种方法的优缺点。

  3. 考虑特殊字符、大小写敏感性等问题,给出灵活的替换方案。

输入描述

  • 一个目标字符串 s
  • 一个待替换的子串 old_sub
  • 一个用于替换的子串 new_sub

输出描述

  • 返回一个新的字符串,将目标字符串中所有出现的 old_sub 替换为 new_sub

示例

示例 ①

输入:

# 调用 replace_substring() 函数
print(replace_substring("hello world", "world", "Python"))
print(replace_substring("hello world", "Java", "Python"))
print(replace_substring("", "world", "Python"))

输出:

"hello Python"
"hello world"
""

代码讲解与多种解法

解法一:使用内置 replace() 方法

Python 提供了内置的 replace() 方法,它可以轻松地将字符串中的某个子串替换为另一个子串。使用该方法,可以快速实现需求。

def replace_substring(s, old_sub, new_sub):
    if not s:
        return ""
    return s.replace(old_sub, new_sub)

优点:

  • replace() 是 Python 的内置方法,使用简单,性能较高。
  • 该方法会替换字符串中出现的所有指定子串,非常适合简单替换任务。

缺点:

  • 无法针对替换的次数进行精细控制。
  • 对于复杂的替换规则(如大小写不敏感替换、正则替换)处理能力有限。

解法二:使用正则表达式 re.sub()

如果要处理更复杂的字符串替换任务,比如基于模式的替换或者大小写不敏感替换,Python 的 re 模块中的 sub() 函数是一个强大的工具。

import re

def replace_substring(s, old_sub, new_sub):
    if not s:
        return ""
    pattern = re.compile(re.escape(old_sub), re.IGNORECASE)  # 大小写不敏感
    return pattern.sub(new_sub, s)

优点:

  • 正则表达式允许更灵活的模式匹配和替换操作。
  • 支持大小写不敏感替换,可以处理复杂的字符串替换需求。

缺点:

  • 语法相对复杂,初学者可能不太容易掌握。
  • 对于简单的替换操作可能显得过于繁琐。

解法三:通过 split()join() 方法替换

可以使用 split() 方法将字符串按子串 old_sub 进行拆分,然后通过 join() 方法将拆分后的字符串列表用 new_sub 连接起来,从而实现替换效果。

def replace_substring(s, old_sub, new_sub):
    if not s:
        return ""
    return new_sub.join(s.split(old_sub))

优点:

  • split()join() 方法组合能够实现替换功能,并且可以手动控制替换细节。
  • 非常适合分隔符替换的场景,如替换文件路径中的反斜杠。

缺点:

  • 当子串出现频率较高时,性能较差,因为 split() 会生成较大的列表。
  • 无法进行复杂的模式匹配替换。

总结与思考

在字符串替换中,根据需求选择合适的方法非常重要。replace() 方法是最简单且高效的替换方式,适合大部分常见的字符串替换需求。re.sub() 则提供了正则表达式支持,适合复杂的替换规则,如大小写不敏感或特定格式的替换。split()join() 的组合方法则在某些特定场景下具有独特的优势,比如当我们只需替换特定分隔符时。

扩展思考:
在某些场景下,可能不仅仅需要替换,还需要计数或统计替换操作的次数。如果有这样的需求,可以结合字符串查找方法或正则表达式的匹配方法来进行处理。

在实际应用中,性能和代码可读性也是需要考虑的因素。如果替换任务非常简单且频繁,replace() 是一个非常好的选择;如果遇到复杂的文本替换场景,如敏感词过滤,正则表达式则更为合适。


希望通过本文你能够掌握字符串替换的多种实现方法,并能够在实际开发中灵活应用这些技术。不同的替换方法适用于不同的场景,选择合适的方法能帮助你编写出更简洁、高效的代码。

持续关注博客,获取更多编程练习与技巧!
作者信息

作者 : 繁依Fanyi
CSDN: https://techfanyi.blog.csdn.net
掘金:https://juejin.cn/user/4154386571867191

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

html初体验标准标签

<!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>Document</title> </head> <body><input type"text"> </body> </html> 内容展示

C和Java实现杨辉三角

C: #include <stdio.h> #define N 15 int main() {int arr[N][N] { 0 }; //初始化int i 0;//行数int j 0;//列数for (i 0; i < N; i){arr[i][0] 1; //每行首元素是 1for (j 0; j < i; j)//为啥j<i呢&#xff1f;因为每一行的个数&#xff08;每一列多少个…

爵士编曲:如何编写爵士钢琴

排列&#xff08;Voicing&#xff09; 由于爵士和声组成音较为复杂&#xff0c;故此衍声排列内容 密集排列&#xff1a;直接堆一起或者左手低音右手和弦音 。 开放排列&#xff1a;各个声部大于等于纯四度&#xff0c;小于八度&#xff0c;符合两只手能弹的情况 混合排列&a…

Python | Leetcode Python题解之第388题文件的最长绝对路径

题目&#xff1a; 题解&#xff1a; class Solution:def lengthLongestPath(self, input: str) -> int:ans, i, n 0, 0, len(input)level [0] * (n 1)while i < n:# 检测当前文件的深度depth 1while i < n and input[i] \t:depth 1i 1# 统计当前文件名的长度l…

深入CSS 布局——WEB开发系列29

CSS 页面布局技术允许我们拾取网页中的元素&#xff0c;并且控制它们相对正常布局流、周边元素、父容器或者主视口/窗口的位置。 一、正常布局流&#xff08;Normal Flow&#xff09; CSS的布局基础是“正常流”&#xff0c;也就是页面元素在没有特别指定布局方式时的默认排列…

文件操作详解:fgetc,fputc,fgets,fputs,fscanf,,fprintf,fread,fwrite的使用和例子 C语言

前言 在日常应用中&#xff0c;我们为了持续的使用一些数据&#xff0c;为了让数据可以在程序退出后可以保存并正常使用&#xff0c;引入了文件的概念和操作。本文分享了一些常用的文件操作函数的使用方法和各自的区别。 一、常用文件顺序读写函数 下面例程所使用的VS工程代码…

【全网最全】《2024高教社杯/国赛》 C题 思路+代码+文献 蒙特卡洛+遗传算法 第一问 农作物的种植策略

​ 领取压缩包 问题 1&#xff1a;建模思路与方法 问题描述 我们需要为某乡村在 2024-2030 年间制定最优的农作物种植方案。考虑的因素包括农作物的销售量、种植成本、亩产量、销售价格、以及不同土地的适宜种植条件等。该问题分为两种情况&#xff1a;(1) 超过部分滞销&#…

【redis】本地windows五分钟快速安装redis

用处&#xff1a;本地自测&#xff0c;有时候公司redis环境不稳定&#xff0c;用自己的 1.下载&#xff0c;github下载一个解压缩在自己想要的位置 选择版本&#xff1a;Redis-7.4.0-Windows-x64-msys2-with-Service&#xff0c;zip GitHub - redis-windows/redis-windows: …

django学习入门系列之第十点《案例 用户管理》

文章目录 展示用户列表添加用户删除用户url中&#xff1f;的作用 往期回顾 展示用户列表 方向 展示用户列表 url函数 获取用户所有的信息基于HTML给他个渲染 views.py from django.shortcuts import render, HttpResponse, redirect# Create your views here.from app01.…

c++162 类的封装和访问

怎么样管理类管理对象 类如何定义对象 #include<iostream> using namespace std;//求圆的面积 class MyCirecle { public:double m_r;//属性 成员变量double m_s; public :double getR(){return m_r;}void setR(double r)//成员函数{m_r r;}double getS(){m_s 3.14…

CMU 10423 Generative AI:lec2

文章目录 1 概述2 部分摘录2.1 噪声信道模型&#xff08;Noisy Channel Models&#xff09;主要内容&#xff1a;公式解释&#xff1a;应用举例&#xff1a; 2.2 n-Gram模型1. 什么是n-Gram模型2. 早期的n-Gram模型3. Google n-Gram项目4. 模型规模与训练数据5. n-Gram模型的局…

EmguCV学习笔记 VB.Net 10.1 人脸检测 CascadeClassifier类

版权声明&#xff1a;本文为博主原创文章&#xff0c;转载请在显著位置标明本文出处以及作者网名&#xff0c;未经作者允许不得用于商业目的。 EmguCV是一个基于OpenCV的开源免费的跨平台计算机视觉库,它向C#和VB.NET开发者提供了OpenCV库的大部分功能。 教程VB.net版本请访问…

视觉语言模型(VLMs)知多少?

最近这几年&#xff0c;自然语言处理和计算机视觉这两大领域真是突飞猛进&#xff0c;让机器不仅能看懂文字&#xff0c;还能理解图片。这两个领域的结合&#xff0c;催生了视觉语言模型&#xff0c;也就是Vision language models (VLMs) &#xff0c;它们能同时处理视觉信息和…

单片机原理

一、单片机基础知识 1.单片机概念 将通用微型计算机基本功能部件集成在一块芯片上构成的一种专用微计算机系统&#xff08;嵌入式系统&#xff09;&#xff0c;用于解决小型被控对象的智能化问题&#xff08;SCM或MCU&#xff09;。 2.单片机组成 3.单片机命名规则 后缀 后缀…

ChatGPT付费创作系统V3.0.6独立版 WEB+H5+小程序端 (新增AI全网搜索+文档解析+豆包AI通道)安装部署教程

播播资源GPT付费体验系统最新版系统是一款基于ThinkPHP框架开发的AI问答小程序&#xff0c;是基于国外很火的ChatGPT进行开发的Ai智能问答小程序。这是一种基于人工智能技术的问答系统&#xff0c;可以实现智能回答用户提出的问题。相比传统的问答系统&#xff0c;ChatGPT可以更…

基于.NET6的WPF总结之MVVM

目录 1. DataContext数据上下文 2. Binding绑定源 2.1 绑定实体 2.2 绑定资源 2.3 ElementName属性指明另一个控件作为数据源 2.4 RelativeSource属性绑定一个相对的数据源 2.4.1 Self&#xff08;绑定自身控件&#xff09; 2.4.2 FindAncestor&#xff08;找上级&#…

vue3获取视频时长、码率、格式等视频详细信息

前言&#xff1a; 我们在上传视频需要视频的帧数等信息的时候&#xff0c;上传组件无法直接读取帧数等信息 方法&#xff1a;通过mediainfo.js来获取视频的帧率、总帧数和视频的总时长 mediainfo.js地址&#xff0c;想详细了解的可以去看看git地址&#xff1a;https://githu…

【C++ Primer Plus习题】11.3

问题: 解答: main.cpp #include <iostream> #include <cstdlib> #include <ctime> #include "vect.h"using namespace std; using namespace VECTOR;int main() {srand(time(0));double direction;Vector step;Vector result(0.0, 0.0);unsigned …

基于 BiLSTM+Attention 实现降雨预测多变量时序分类——明日是否降雨

前言 系列专栏:【深度学习&#xff1a;算法项目实战】✨︎ 涉及医疗健康、财经金融、商业零售、食品饮料、运动健身、交通运输、环境科学、社交媒体以及文本和图像处理等诸多领域&#xff0c;讨论了各种复杂的深度神经网络思想&#xff0c;如卷积神经网络、循环神经网络、生成对…

uniapp解决页面跳转时,含有base64的数据丢失问题

由于url长度的限制&#xff0c;base64数据过长可能导致数据丢失&#xff0c;以至于base64图片显示不出来或者格式错误。 解决办法&#xff1a; 跳转前进行base64编码&#xff1a;encodeURIComponent 接收数据时&#xff0c;对base64进行解码&#xff1a;decodeURIComponent