java正则替换标点

本文深入探讨了如何使用正则表达式和Java编程语言去除字符串中的各种标点符号,包括全角、半角、横排、竖排等。详细介绍了不同版本的Java环境对全角单引号对、双引号对处理的区别,并提供了一个通用的代码示例,用于在多种环境中高效去除标点符号。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

测试代码如下:
  1. classT{
  2. publicstaticvoidmain(String...args){
  3. Stringstr="!!!!去符号标号!!当然。!!..**半角";
  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的说明


来自于 http://www.unicode.org/reports/tr18/
分享到:
评论
2 楼 RonQi2011-08-19
我试了一下,根据API,\p{Punct}匹配的标点是这些,
Java代码 收藏代码
  1. \p{Punct}标点符号:!"#$%&'()*+,-./:;<=>?@[\]^_`{|}~

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值