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=>ar[0].split("、"));//split:拆分

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

//第2步:var newarr=arr.map(ar=>ar[0].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=>ar[0].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=>ar[0].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;

}

相关推荐
拉不动的猪12 小时前
移动端调试工具VConsole初始化时的加载阻塞问题
前端·javascript·微信小程序
大金乄14 小时前
封装一个vue2的elementUI 表格组件(包含表格编辑以及多级表头)
前端·javascript
Lee川16 小时前
解锁 JavaScript 的灵魂:深入浅出原型与原型链
javascript·面试
swipe17 小时前
从原理到手写:彻底吃透 call / apply / bind 与 arguments 的底层逻辑
前端·javascript·面试
Lee川19 小时前
探索JavaScript的秘密令牌:独一无二的`Symbol`数据类型
javascript·面试
Lee川19 小时前
深入浅出JavaScript事件机制:从捕获冒泡到事件委托
前端·javascript
光影少年19 小时前
async/await和Promise的区别?
前端·javascript·掘金·金石计划
codingWhat19 小时前
如何实现一个「万能」的通用打印组件?
前端·javascript·vue.js
前端Hardy21 小时前
别再无脑用 `JSON.parse()` 了!这个安全漏洞你可能每天都在触发
前端·javascript·vue.js
前端Hardy21 小时前
别再让 `console.log` 上线了!它正在悄悄拖垮你的生产系统
前端·javascript·vue.js