正则表达式,匹配逗号
str = str.replaceAll("(\\d),,+(\\d)", "$1,$2");
System.out.println(str);
输出结果:a:122,122,21,2,,,343。根据输出结果我试验了下,2,,,343没有被匹配,原因是2被之前的21,,2匹配过并被替换过。求解决方法
我的需求是,匹配数字之间的两个以上的逗号并把这些逗号换成一个。一定要是数字之间的 展开
String str = "a:122,,122,,,21,,2,,,343";
str = str.replaceAll("(?<=\\d+),{2,}(?=\\d+)", ",");
System.out.println(str);
正则表达式的"鼻祖"或许可一直追溯到科学家对人类神经系统工作原理的早期研究。美国新泽西州的Warren McCulloch和出生在美国底特律的Walter Pitts这两位神经生理方面的科学家,研究出了一种用数学方式来描述神经网络的新方法,他们创造性地将神经系统中的神经元描述成了小而简单的自动控制元,从而作出了一项伟大的工作革新。
在1951 年,一位名叫Stephen Kleene的数学科学家,他在Warren McCulloch和Walter Pitts早期工作的基础之上,发表了一篇题目是《神经网事件的表示法》的论文,利用称之为正则集合的数学符号来描述此模型,引入了正则表达式的概念。正则表达式被作为用来描述其称之为"正则集的代数"的一种表达式,因而采用了"正则表达式"这个术语。
之后一段时间,人们发现可以将这一工作成果应用于其他方面。Ken Thompson就把这一成果应用于计算搜索算法的一些早期研究,Ken Thompson是 Unix的主要发明人,也就是大名鼎鼎的Unix之父。Unix之父将此符号系统引入编辑器QED,然后是Unix上的编辑器ed,并最终引入grep。Jeffrey Friedl 在其著作《Mastering Regular Expressions (2nd edition)》(中文版译作:精通正则表达式,已出到第三版)中对此作了进一步阐述讲解,如果你希望更多了解正则表达式理论和历史,推荐你看看这本书。
自此以后,正则表达式被广泛地应用到各种UNIX或类似于UNIX的工具中,如大家熟知的Perl。Perl的正则表达式源自于Henry Spencer编写的regex,之后已演化成了pcre(Perl兼容正则表达式Perl Compatible Regular Expressions),pcre是一个由Philip Hazel开发的、为很多现代工具所使用的库。正则表达式的第一个实用应用程序即为Unix中的 qed 编辑器。
用这个吧:\w+?
\d{1,2},\d{4},问号后面有空格
如果不要逗号,可以这样:(\w+?
\d{1,2}),(\d{4}),取匹配子文本1和2,就可以了
你的
[a-z]+\s
[0-9]{2},[0-9]{4},前面的
[a-z]+,没有包括大写和数字;[0-9]{2},匹配两次,一个数字的不匹配;式中的逗号是在匹配文本里面的,只是不知道你是否需要。
str = str.replaceAll("(?<=\\d+),{2,}(?=\\d+)", ",");
System.out.println(str);