有这么一个字符串:a1=1,a2=X2{b1=1,b2=X3{c1=1,c2=2}},a3=X4{b1=1}
想写一个正则表达式,让下面code的执行结果是:
result(以逗号为token来分割字符串,逗号在"{"和"}"里面的忽略其做为token):
a1=1
a2=X2{b1=1,b2=X3{c1=1,c2=2}}
a3=X4{b1=1}
code:
Pattern p1 = Pattern.compile("(?<=^|,)(?:[^,{]++(?:\\{[^{}]*+(?:\\{[^{}]++\\})*+\\})*+)*+(?=,|$)");
Matche ...
- 浏览: 1501 次
- 性别:


- 详细资料
搜索本博客
最近加入圈子
最新评论
-
是正则表达式还是ANTLR的 ...
如果格式是逗号和{}这些固定的, 自己写个解析程序很简单的, 效率又不知高多少倍 ...
-- by 歆渊 -
是正则表达式还是ANTLR的 ...
Pattern p1 = Pattern.compile("(?<=^ ...
-- by chikaiwang -
是正则表达式还是ANTLR的 ...
个人感觉用antlr比较好,但是项目中很少用到,没仔细看过
-- by hbcui1984 -
是正则表达式还是ANTLR的 ...
郁闷,原来Java不支持正则表达式的无限递归匹配。
-- by chikaiwang






评论排行榜