JS关于 replace 取值、替换第几个匹配项问题小结
作者:橙子家 时间:2024-04-25 13:11:05
在日常开发中,经常遇到针对字符串的替换、截取,知识点比较碎容易混淆,特此总结一下,仅供参考。
一、替换第一个匹配项
字符串替换
let strtest = "0123测试replace456测试replace789测试replace0"
console.log("原字符串:" + strtest)
let outstr = strtest.replace("测试","ceshi")
console.log("输出字符串:" + outstr)
// 原字符串:0123测试replace456测试replace789测试replace0
// 输出字符串:0123ceshireplace456测试replace789测试replace0
正则表达式替换
当直接在被替换字符串恰后加上 / 时,不添加修饰符,就等同于直接字符串替换。
let strtest = "0123测试replace456测试replace789测试replace0"
console.log("原字符串:" + strtest)
let outstr = strtest.replace(/测试/, "ceshi")
console.log("输出字符串:" + outstr)
// 原字符串:0123测试replace456测试replace789测试replace0
// 输出字符串:0123ceshireplace456测试replace789测试replace0
二、替换全部匹配项
字符串分组再联合
let strtest = '0123测试replace456测试replace789测试replace0';
console.log("原字符串:" + strtest)
let arrstr = strtest.split("测试");
let outstr = arrstr.join("ceshi");
console.log("输出字符串:" + outstr)
// 原字符串:0123测试replace456测试replace789测试replace0
// 输出字符串:0123ceshireplace456ceshireplace789ceshireplace0
正则表达式替换
格式:/待替换的字符串/g、/待替换的字符串/mgi。
  g:执行全局匹配,替换全部匹配项;
  i:不区分大小写;
  m:多行匹配。
gim 可所以组合使用。
let strtest = "0123测试replace456测试replace789测试replace0"
console.log("原字符串:" + strtest)
let outstr = strtest.replace(/测试/g, "ceshi")
// 另一种写法:
// let reg = new RegExp("测试", "g")
// let outstr = strtest.replace(reg, "ceshi")
console.log("输出字符串:" + outstr)
// 原字符串:0123测试replace456测试replace789测试replace0
// 输出字符串:0123ceshireplace456ceshireplace789ceshireplace0
三、替换第 n 个匹配项
下边以第二个为例。
字符串分组再联合
思路:先通过被替换项分组,再根据目标位数把整个分组分为两个部分,在通过替换字符串联合。
let num = 2 // 定义替换第二个匹配项
let strtest = '0123测试replace456测试replace789测试replace0';
console.log("原字符串:" + strtest)
let arrstr = strtest.split("测试");
if(arrstr.length < num)
return
let arrstr1=[],arrstr2=[]
for(let ii=0;ii<arrstr.length;ii++){
if(ii < num)
arrstr1.push(arrstr[ii])
else
arrstr2.push(arrstr[ii])
}
let outstr = arrstr1.join("测试")+"ceshi"+arrstr2.join("测试");
console.log("输出字符串:" + outstr)
// 原字符串:0123测试replace456测试replace789测试replace0
// (index):59 输出字符串:0123测试replace456ceshireplace789测试replace0
正则表达式实现
将第一个匹配项跳过,并把第二个匹配项之前的内容标识为变量。
let strtest = '0123测试replace456测试replace789测试replace0';
console.log("原字符串:" + strtest)
let outstr = strtest.replace(/((?:.*?测试.*?){1}.*?)测试/m, "$1-ceshi-")
// ?: 表示:其后边的 pattern 匹配但不获取。匹配项被标识为 $1,后续会引用
// .*? 表示:.* 除 '/n' 之外的任意个任意字符
// {1} 表示:其前边的 pattern 出现一次
// /pattern/m 表示: m 全局查询
console.log("输出字符串:" + outstr)
// 原字符串:0123测试replace456测试replace789测试replace0
// 输出字符串:0123测试replace456测试replace789-ceshi-replace0
参考:https://stackoverflow.com/questions/42943096/replace-nth-match-of-matches-with-regex
四、替换指定标记之间的内容
字符串分组再联合
let strtest = '0123<Object>replace456测试replace78</Object>9测试replace0';
let startstr = "<Object>"
let endstr = "</Object>"
if (strtest.indexOf(startstr) > strtest.indexOf(endstr))
return
console.log("原字符串:" + strtest)
let arr = strtest.split(startstr)
let arr2 = arr[1].split(endstr)
let resultstr = arr2[0]
let outstr = startstr + resultstr + endstr
console.log("输出字符串:" + outstr)
// 原字符串:0123<Object>replace456测试replace78</Object>9测试replace0
// 输出字符串:<Object>replace456测试replace78</Object>
let strtest = '0123<Object>replace456测试replace78</Object>9测试replace0';
let startstr = "<Object>"
let endstr = "</Object>"
if (strtest.indexOf(startstr) > strtest.indexOf(endstr))
return
console.log("原字符串:" + strtest)
let arr = strtest.split(startstr)
let arr2 = arr[1].split(endstr)
let resultstr = arr2[0]
let outstr = startstr + resultstr + endstr
console.log("输出字符串:" + outstr)
// 原字符串:0123<Object>replace456测试replace78</Object>9测试replace0
// 输出字符串:<Object>replace456测试replace78</Object>
正则表达式方法 replace()、match()、exec()
替换为指定字符串:( replace() )
let strtest = '0123<Object>replace456测试replace78</Object>9测试replace0';
console.log("原字符串:" + strtest)
let outstr = strtest.replace(/<Object>(.*?)<\/Object>/m, "-ceshi-") // \ 为转义字符
console.log("输出字符串:" + outstr)
// 原字符串:0123<Object>replace456测试replace78</Object>9测试replace0
// 输出字符串:0123-ceshi-9测试replace0
取出带标记字符串的内容:( match() )
let strtest = '0123<Object>replace456测试replace78</Object>9测试replace0';
console.log("原字符串:" + strtest)
let outstr = strtest.match(/<Object>(.*?)<\/Object>/m)
console.log("输出字符串:" + outstr)
// 原字符串:0123<Object>replace456测试replace78</Object>9测试replace0
// 输出字符串:<Object>replace456测试replace78</Object>
当可能有多个匹配项时:( exec() )
let strtest = "这是<Object>要提取的内容</Object>,还有<Object>另一个内容</Object>"
console.log("原字符串:" + strtest)
let regex = /<Object>(.*?)<\/Object>/gm
const matches = []
let match
while ((match = regex.exec(strtest)) !== null) {
matches.push(match[1])
console.log(match)
}
console.log("输出全部匹配项:", matches)
// 原字符串:这是<Object>要提取的内容</Object>,还有<Object>另一个内容</Object>
// (2) ["<Object>要提取的内容</Object>", "要提取的内容", index: 2, input: "这是<Object>要提取的内容</Object>,还有<Object>另一个内容</Object>", groups: undefined]
// (2) ["<Object>另一个内容</Object>", "另一个内容", index: 28, input: "这是<Object>要提取的内容</Object>,还有<Object>另一个内容</Object>", groups: undefined]
// 输出全部匹配项: (2) ["要提取的内容", "另一个内容"]
来源:https://www.cnblogs.com/czzj/p/js_replace.html
标签:js,replace,取值,替换,匹配项
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
python卸载后再次安装遇到的问题解决
2022-06-10 01:58:09
![](https://img.aspxhome.com/file/2023/1/89231_0s.png)
mysql 8.0.22 安装配置方法图文教程
2024-01-24 20:30:05
![](https://img.aspxhome.com/file/2023/0/69840_0s.png)
Python Flask-web表单使用详解
2022-07-14 01:55:59
![](https://img.aspxhome.com/file/2023/7/90747_0s.jpg)
SQLServer 全文检索(full-text)语法
2011-12-01 10:38:22
Python之string编码问题
2021-08-28 15:25:48
![](https://img.aspxhome.com/file/2023/5/95885_0s.jpg)
Python爬虫实战之虎牙视频爬取附源码
2021-04-02 01:23:27
![](https://img.aspxhome.com/file/2023/9/64269_0s.png)
学生信息管理系统python版
2023-10-17 07:32:34
使用Python横向合并excel文件的实例
2023-09-19 21:20:18
![](https://img.aspxhome.com/file/2023/7/87817_0s.jpg)
使用TFRecord存取多个数据案例
2023-07-14 22:26:34
SQL2000中的默认sa帐号的修改与删除方法
2024-01-22 22:54:59
python批量telnet检测IP地址的端口是否开放
2023-12-28 12:12:24
![](https://img.aspxhome.com/file/2023/9/118649_0s.png)
使用Spark进行实时流计算的方法
2023-02-13 10:39:34
![](https://img.aspxhome.com/file/2023/3/107173_0s.png)
Python数字/字符串补零操作实例代码
2021-07-13 03:16:57
![](https://img.aspxhome.com/file/2023/4/80384_0s.png)
详解js前端代码异常监控
2024-04-22 13:06:26
![](https://img.aspxhome.com/file/2023/0/135800_0s.png)
python读取与处理netcdf数据方式
2021-11-09 02:45:01
对python调用RPC接口的实例详解
2022-12-30 00:09:20
深入解析MySQL索引的原理与优化策略
2024-01-19 02:29:02
Python中装饰器兼容加括号和不加括号的写法详解
2022-08-09 10:46:25
Python基于locals返回作用域字典
2021-05-17 22:02:43
Python的GUI编程之Pack、Place、Grid的区别说明
2022-10-19 05:53:57
![](https://img.aspxhome.com/file/2023/6/95316_0s.jpg)