java正则替换标点

感谢【火龙果】,钦佩他的研究精神。
http://topic.csdn.net/u/20080925/15/41b814bf-fcaf-4b37-be91-10561a102768.html

测试代码如下:
  1. class T {
  2.   public static void main(String... args) {
  3.     String str = "!!!!去符号标号!!当然。!!..**半角";
  4.     System.out.println(str);
  5.     System.out.println(str.replaceAll("\\p{Punct}"""));
  6.     System.out.println(str.replaceAll("\\pP"""));
  7.   }
  8. }

运行结果
!!!!去符号标号!!当然。!!..**半角
!!去符号标号!!当然。半角
去符号标号当然半角


果子的解释
采用 Unicode 标点属性方式的正则表达式,可以去掉所有的标点符号, 
包括全角、半角、横排、竖排等的标点符号。 

注意一下,如果在 JDK 5 或以下的环境中,全角单引号对、双引号对 
无法替换掉,这是 JDK 5 及以下版本缺失的,在 JDK 6 中由于加入了 
Pi 和 Pf 两个 Unicode 子属性,因此就能替换掉。 

在 JDK 6 以下的版本中可以这样: 
  1. str = str.replaceAll("[\\pP‘’“”]""");
我查到的 \pP的说明
java正则替换标点_第1张图片

来自于  http://www.unicode.org/reports/tr18/
分享到:   
请教如何实现下面这 一个功能 |  一种我无法回答的问题,希望不要这样提问
  • 2008-09-26 07:00
  • 浏览 2957
  • 评论(2)
  • 相关推荐
评论
2 楼  RonQi 2011-08-19  
我试了一下,根据API,\p{Punct}匹配的标点是这些,
Java代码   收藏代码
  1. \p{Punct} 标点符号:!"#$%&'()*+,-./:;<=>?@[\]^_`{|}~   

其中
Java代码   收藏代码
  1. $+<=>^`|~  

这几个标点是\pP匹配不到的,是不是这俩一块儿用是匹配最全的?
Java代码   收藏代码
  1. [\\pP\\p{Punct}]  
1 楼  RonQi 2011-08-19  
学习了,还带了原文链接,顺便过去学习了火龙果的高见,很好

你可能感兴趣的:(java,jdk,正则表达式,api,测试)