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;

}

相关推荐
工程师老罗20 小时前
Image(图像)的用法
java·前端·javascript
早點睡39020 小时前
ReactNative项目OpenHarmony三方库集成实战:react-native-swiper
javascript·react native·react.js
jump_jump20 小时前
深入 JavaScript Iterator Helpers:从 API 到引擎实现
javascript·性能优化
swipe21 小时前
把 JavaScript 原型讲透:从 `[[Prototype]]`、`prototype` 到 `constructor` 的完整心智模型
前端·javascript·面试
Dxy123931021621 小时前
JS发送请求的方法详解
开发语言·javascript·ecmascript
harrain1 天前
antvG2折线图和区间range标记同时绘制
前端·javascript·vue.js·antv·g2
网络点点滴1 天前
组件通信-作用域插槽
前端·javascript·vue.js
LZQ <=小氣鬼=>1 天前
React 图片放大镜组件使用文档
javascript·react.js·前端框架·ecmascript
kyriewen111 天前
异步编程:从“回调地狱”到“async/await”的救赎之路
开发语言·前端·javascript·chrome·typescript·ecmascript·html5
早點睡3901 天前
ReactNative项目Openharmony三方库集成实战:@react-native-clipboard/clipboard
javascript·react native·react.js