技术解析

各位大佬,求一个正则。
0
2021-08-09 22:14:57
idczone

我正在开发一个前端的类 Excel 计算功能。

这是一个错误的公式,要得出“H4H4H4”、“J3J3J3J3”,可能有多个匹配。

=A1+M2-N2+H4H4H4+G7+H5/J3*PREXM('','','')

=A1+M2-N2+H4H4+G7+H5/J3J3J3J3*PREXM('','','')

正确的是这样的:

=A1+M2-N2+H4+G7+H5/J3*PREXM('','','')


假设规则是 去掉重复的 一个大写字母一个数字吧
```js
g = /([A-Z]\d)\1+/g
s = "A1+M2-N2N2+H4H4+G7+H5/J3J3J3J3*PREXM('','','')"
s.replace(g, '$1')
```

`([A-Z]\d){2,}` 就可以匹配到了吧?

2 楼的就可以

如果是 H1H2H3H4 这种怎么办?
是否有 AA1234 这种地址? [A-Z]\d 看上去不够



ganxi 感谢。看起来可行。

你这个也可,但是不能满足 4 楼提出的那种情况。非常感谢。

.replace(/([A-Z]+\d+)\1+/g, '$1')

我觉得你需要的是这个: https://www.npmjs.com/package/excel-formula-sdk

感谢,我们已有一个词法解析器,结合了自己的业务。

工具测试下 https://tools.fun/regexp.html

2 楼不错

感觉为了以后的方便,该这样比较好
g = /([A-Z]+\d+)\1+/g

数据地带为您的网站提供全球顶级IDC资源
在线咨询
专属客服