8-7 WPS JS宏 正则表达式 元字符应用-提取连续数字

8-7 WPS JS宏 正则表达式 元字符应用-提取连续数字

一、元字符

+:连续

二、示例提取连续数字

代码如下:

function test(){

var arr=Range("b2",Range("b65536").End(xlUp)).Value();

var newarr=arr.map(ar=>ar\[0.split("、").map(v=>v.match(/\d/g).join("")).join("、")]);

//分段展示:

//第1步:var newarr=arr.map(ar=>ar0.split("、"));//split:拆分

//结果:newarr=\["刘小明1000","陈好2000","李五3000","徐丽2500","程六2000","熊霞3000"]

//第2步:var newarr=arr.map(ar=>ar0.split("、").map(v=>v.match(/\d/g)));//match:搜索返回

//结果:newarr=\[\["1","0","0","0","2","0","0","0"],\["3","0","0","0","2","5","0","0"],\["2","0","0","0","3","0","0","0"]]

//第3步:var newarr=arr.map(ar=>ar0.split("、").map(v=>v.match(/\d/g).join("")));//join:合并

//简单方法:+:连续,match(/\d/g)中写入+,如match(/\d+/g),就可以省略join("")

//结果:newarr=\["1000","2000","3000","2500","2000","3000"]

//第4步:var newarr=arr.map(ar=>ar0.split("、").map(v=>v.match(/\d/g).join("")).join("、"));//join:合并

//结果:newarr="1000、2000","3000、2500","2000、3000"

//第5步:var newarr=arr.map(ar=>ar\[0.split("、").map(v=>v.match(/\d/g).join("")).join("、")]);用\[\]:横向输出改竖向输出

//结果:newarr=\["1000、2000","3000、2500","2000、3000"]

Console.log(JSON.stringify(newarr))//打印数组

Range("c2").Resize(arr.length,1).Value2=newarr;

}

相关推荐
JieE2127 小时前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
冬奇Lab9 小时前
AI Workflow 定义的四次演进:从 Markdown 到 JS 脚本,再到分布式多 Agent
javascript·人工智能·agent
一颗烂土豆15 小时前
Meshopt 压缩深度解析,为什么它比 Draco 更快
前端·javascript·webgl
kyriewen17 小时前
同事每天催我 Code Review,我写了个脚本让 AI 替我 review PR——现在他反过来催 AI 了
前端·javascript·ai编程
weedsfly20 小时前
迭代器、生成器与异步迭代——让数据“按需流动”的艺术
前端·javascript
假如让我当三天老蒯20 小时前
前端跨域解决方案(学习用)
前端·javascript·面试
铁皮饭盒1 天前
Bun 哪比 Node.js 快?
javascript·后端
JieE2121 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
candyTong1 天前
RTK 技术原理:一次典型会话里,80% 上下文是怎么省下来的
javascript·后端·架构
_柳青杨2 天前
深入理解 JavaScript 事件循环
前端·javascript