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;

}

相关推荐
xuankuxiaoyao7 分钟前
Vue.js实践-组件基础下
前端·javascript·vue.js
小白学大数据7 分钟前
JS 混淆加密下的 Python 爬虫解决方案
javascript·爬虫·python
大家的林语冰1 小时前
前端周刊:axios 疑遭朝鲜黑客“钓鱼“;CSS 新函数上线;npm 上线深色主题;Oxlint 兼容表;ESLint 支持 Temporal......
前端·javascript·css
竹林8183 小时前
用ethers.js连接MetaMask实现Web3钱包登录:从踩坑到稳定运行的完整记录
前端·javascript
心连欣3 小时前
从零开始,学习所有指令!
前端·javascript·vue.js
openKaka_5 小时前
从 scheduleUpdateOnFiber 到 Root 微任务调度:React 如何把更新交给调度系统
开发语言·前端·javascript
前进的李工5 小时前
智能Agent实战指南:记忆组件嵌入技巧(记忆)
开发语言·前端·javascript·python·langchain·agent
IOT.FIVE.NO.16 小时前
Codex Skill 内部结构解析:从 SKILL.md 到 scripts、references、assets
前端·javascript·人工智能·笔记·html
daols887 小时前
vue甘特图vxe-gantt如何实现拖拽任务条时如有已关联依赖线,同时更新依赖任务的日期的方式
javascript·vue.js·甘特图