JS 中字符串 replace 的高级用法

原文地址:https://www.jeremyjone.com/809/,转载请注明。


缘起

说来惭愧,一直用 replace 替换,却一直没注意第二个参数可以放函数,也一直没用到。今天在做 excel 下载时发现一直报表名的错误,发现名字超长了,也才发现原来 excel 表名最长好像到31个字符。

想着简单,把中间截取一下替换成 ~ 就可以了。然后发现 replace 不能一次性满足我,虽然用两次可以解决,但是不能忍,于是去 文档 恶补了一下。

基本用法

基本用法我们天天用,没啥说的:

var s = 'abcde';
s = s.replace(/bc/, '~');
console.log(s); // 'a~de'

高级用法

函数作为参数

高级用法就是第二个参数可以传入一个函数:

function(match, p1, p2, ..., pn, offset, str) {}

参数可以简单理解为:

参数含义
match匹配到的全部内容
p1,p2,…pn匹配到的分组内容
offset匹配到的子字符串在原字符串中的偏移量
str原始字符串

函数需要返回一个新的字符串值,该值就是我们需要接收的值。

对应我的需求,现在有一个超长的名字,比如它是:abcdefghijklmnopqrstuvwxyz1234567890,现在需要将其缩短,策略是前20个字符保留,后5个字符保留,中间所有字符替换为 ~,就可以使用上面函数:

var name = "abcdefghijklmnopqrstuvwxyz1234567890";
name = name.replace(/^.{20}(.*).{5}$/g, function(match, p1, offset, str) {
    return match.replace(p1, "~");
})

就会得到需要的 abcdefghijklmnopqrst~67890

参数字符串

使用参数字符串,需要通过关键字符 $ 来获取,平时使用时如果用到过 $ 作为替换字符的话会有注意:

参数含义
$$插入一个 $
$&插入匹配的子串
$`插入当前匹配的子串左边的内容
$’插入当前匹配的子串右边的内容
$n获取第n个获取到的子串,同上面的 p1,p2,…,pn

它可以获取对应的内容,但是不要直接对参数字符串进行修改:

// 错误,得到结果为 ~
name = name.replace(/^.{20}(.*).{5}$/g, "$1".replace(/.*/, "~"));

上面这种写法是不会得到正确结果的,因为 "$1".replace(/.*/, "~") 会先被解析成字符串字面量,与 $& 效果相同,不会再将 $1 当做一个参数。所以这样得到的结果是且仅仅是一个 ~

得到 ~ 的步骤是:

  • $1 替换为了 ~,所以是将 ~ 作为了替换内容
  • 正则匹配了全局内容,所以全局内容被替换为了 ~
  • replace 返回的结果是 ~name 被重新赋值为 ~

所以,这种方式不能在参数字符串中直接修改内容。

那么为了得到正确结果,有没有可行的方式呢?

答案是肯定的,对应上面使用函数的例子,可以使用参数字符串进行替换:

// 正确
name = name.replace(/^(.{20})(.*)(.{5})$/g, "$1~$3");

此时替换内容 "$1~$3" 中的 $1$3 是会被当成参数的,内部实现会将其直接替换。

你学会了么?

### Python 字符串 `replace()` 方法使用指南 `replace()` 是 Python 中用于字符串替换的重要方法,其语法为: ```python str.replace(old, new[, count]) ``` 其中,`old` 是需要被替换的子字符串,`new` 是用来替换的新子字符串,而可选参数 `count` 表示最多替换的次数。若未指定 `count`,则会替换所有匹配项[^5]。 #### 基础用法 `replace()` 方法可以用于简单的字符串替换操作。例如: ```python s = "Hello, World!" result = s.replace("World", "Python") print(result) # 输出: Hello, Python! ``` 上述代码中,字符串 `"World"` 被替换为 `"Python"`,并返回一个新的字符串。原字符串保持不变,因为字符串是不可变对象[^4]。 #### 指定替换次数 通过提供 `count` 参数,可以控制替换的次数。例如: ```python s = "apple banana apple cherry apple" result = s.replace("apple", "orange", 2) print(result) # 输出: orange banana orange cherry apple ``` 在该示例中,前两个 `"apple"` 被替换为 `"orange"`,其余保持不变[^4]。 #### 未找到匹配时的处理 如果指定的子字符串不存在于原字符串中,则 `replace()` 方法会直接返回原始字符串,不做任何修改。例如: ```python s = "Hello, World!" result = s.replace("abc", "Python") print(result) # 输出: Hello, World! ``` 这表明如果未找到匹配项,原字符串将被原样返回[^4]。 #### 链式调用 `replace()` 方法支持链式调用,这意味着可以在一个语句中进行多次替换。例如: ```python s = "I like Java and JavaScript" result = s.replace("Java", "Python").replace("like", "love") print(result) # 输出: I love Python and PythonScript ``` 在该示例中,首先将 `"Java"` 替换为 `"Python"`,然后将 `"like"` 替换为 `"love"`,最终得到新的字符串[^4]。 #### 注意事项 1. **区分大小写**:`replace()` 方法默认区分大小写,仅替换完全匹配的文本。例如,若想替换 `"Dog"`,则 `"dog"` 不会被替换。 2. **不修改原始字符串**:由于字符串是不可变对象,`replace()` 方法不会修改原始字符串,而是返回一个新的字符串[^4]。 3. **复杂替换需求**:如果需要进行不区分大小写的替换或模式匹配,建议使用 `re` 模块的 `sub()` 方法。 #### 示例代码 以下是一个综合示例,展示了 `replace()` 方法的多种用法: ```python # 基础替换 message = "I really like dogs" new_message = message.replace('dog', 'cat') print(new_message) # 输出: I really like cats # 指定替换次数 s = "apple banana apple cherry apple" result = s.replace("apple", "orange", 2) print(result) # 输出: orange banana orange cherry apple # 未找到匹配时 s = "Hello, World!" result = s.replace("abc", "Python") print(result) # 输出: Hello, World! # 链式调用 s = "I like Java and JavaScript" result = s.replace("Java", "Python").replace("like", "love") print(result) # 输出: I love Python and PythonScript ``` 通过上述示例和说明,可以全面了解 `replace()` 方法在 Python 中的使用方式及其特点[^1]。
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值