我正在尝试按单个或多个字母出现来拆分字符串。
例如:
aaabbcapppp
,将产生数组, ["aaa", "bb", "c", "a", "pppp"]
我最无效率的想法是只是利用newArray = str.split("");
并根据我的需要重建阵列。我认为有一个更有效的解决方案。
这样的事情会起作用:
"aaabbcapppp".match(/(.)\1*/g) // ["aaa", "bb", "c", "a", "pppp"]
(.)
匹配在组1中捕获的任何单个字符,然后匹配重复重复零次或多次的同一字符(\1
是与组1中匹配的后向引用完全匹配的反向引用)。
要仅匹配拉丁字母,请考虑使用[a-z]
,例如:
"aaa-bbca!!pppp".match(/([a-z])\1*/g) // ["aaa", "bb", "c", "a", "pppp"]
在此,-
和!!
不包括在结果数组中。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句