字符串中正则表达式应用
2015-06-27 21:29
330 查看
正则表达式在字符串中主要用来进行匹配作用。我这里记录一下String中正则表达式的两种途径:
1 String类的自建功能
2 利用Pattern和Matcher的操作字符串
下面是具体代码
1 String类的自建功能
/***
* 字符串自带表达式处理
*/
public static void stringRegex(){
System.out.println("55".matches("\\d+"));//String自身就可以对正则表达式格式做简单检查
System.out.println("-90".matches("(\\+|-)?\\d+"));
System.out.println("-90.6".matches("(\\+|-)?\\d+"));
}
说明:这里面通过字符串自身功能进行匹配,查找字符串是否符是数字。
表达式"\\d+"表示正整数,表达式(\\+|-)?\\d+ 表示正负整数.
字符串中 split和replace中也使用正则表达式
2利用Pattern和Matcher的操作字符串
/**从字符串中检查符合相应规范的字符串 */
public static void findFromSource(){
String source ="<?xml version=\"1.0\" encoding=\"UTF-8\"?>"+
"<plist version=\"1.0\">"+
"<dict>"+
"<key>MessageType</key> "+
"<string>TokenMessage</string> "+
"<key>PushMagic</key> "+
"<string>1234556</string> "+
"<key>Token</key> "+
" <data> "+
"tokendata"+
" </data> "+
"<key>Topic</key>"+
"<string>com.apple.apn</string> "+
"<key>UDID</key> "+
"<string>1234567890</string> "+
"<key>UnlockToken</key> "+
"<data>"+
"this is unlockToken字符串"+
"</data>"+
"</dict>"+
"</plist>";
Pattern pattern = Pattern.compile("<key>Topic</key>\\s*<string>\\s*([^\\s]*)\\s*</string>");
Matcher matcher = pattern.matcher(source);
if(matcher.find()){
System.out.println(matcher.group(1));////组1,就是()里面的内容,也就是Topic的值
System.out.println(matcher.group());
}
// String words = "this is a good";//将返回true
String words = "this is a good!";//将返回false
Pattern pattern2 = Pattern.compile("[\\w|\\s]*");//匹配字符和空格
Matcher matcher2 = pattern2.matcher(words);
System.out.println(matcher2.matches());//是从头开始匹配,完全匹配才返回true
}
说明: 这段代码还是比较实用的,在第一部分功能是在大量字符串中找出符合正则表达式的那一部分。
其中matcher中有组的概念,组就是用()括起来的内容 ,例如:A(B(C))D 组0 就是ABCD ,组1是BC,组2是C
第二部分功能就是利用matches方法检验字符是否符合表达式要求。
参考资料:Java编程思想。
1 String类的自建功能
2 利用Pattern和Matcher的操作字符串
下面是具体代码
1 String类的自建功能
/***
* 字符串自带表达式处理
*/
public static void stringRegex(){
System.out.println("55".matches("\\d+"));//String自身就可以对正则表达式格式做简单检查
System.out.println("-90".matches("(\\+|-)?\\d+"));
System.out.println("-90.6".matches("(\\+|-)?\\d+"));
}
说明:这里面通过字符串自身功能进行匹配,查找字符串是否符是数字。
表达式"\\d+"表示正整数,表达式(\\+|-)?\\d+ 表示正负整数.
字符串中 split和replace中也使用正则表达式
2利用Pattern和Matcher的操作字符串
/**从字符串中检查符合相应规范的字符串 */
public static void findFromSource(){
String source ="<?xml version=\"1.0\" encoding=\"UTF-8\"?>"+
"<plist version=\"1.0\">"+
"<dict>"+
"<key>MessageType</key> "+
"<string>TokenMessage</string> "+
"<key>PushMagic</key> "+
"<string>1234556</string> "+
"<key>Token</key> "+
" <data> "+
"tokendata"+
" </data> "+
"<key>Topic</key>"+
"<string>com.apple.apn</string> "+
"<key>UDID</key> "+
"<string>1234567890</string> "+
"<key>UnlockToken</key> "+
"<data>"+
"this is unlockToken字符串"+
"</data>"+
"</dict>"+
"</plist>";
Pattern pattern = Pattern.compile("<key>Topic</key>\\s*<string>\\s*([^\\s]*)\\s*</string>");
Matcher matcher = pattern.matcher(source);
if(matcher.find()){
System.out.println(matcher.group(1));////组1,就是()里面的内容,也就是Topic的值
System.out.println(matcher.group());
}
// String words = "this is a good";//将返回true
String words = "this is a good!";//将返回false
Pattern pattern2 = Pattern.compile("[\\w|\\s]*");//匹配字符和空格
Matcher matcher2 = pattern2.matcher(words);
System.out.println(matcher2.matches());//是从头开始匹配,完全匹配才返回true
}
说明: 这段代码还是比较实用的,在第一部分功能是在大量字符串中找出符合正则表达式的那一部分。
其中matcher中有组的概念,组就是用()括起来的内容 ,例如:A(B(C))D 组0 就是ABCD ,组1是BC,组2是C
第二部分功能就是利用matches方法检验字符是否符合表达式要求。
参考资料:Java编程思想。
相关文章推荐
- Eclipse修改Project的目录位置
- Oracle基础(一)
- Fedora 14 NFS网络系统的挂载
- eclipse自动生成hibernate配置文件插件MiddleGenIDE
- memcached基本命令学习
- 徐宜生,CSDN博客专家、沪江网软件工程师
- [转]getGlobalVisibleRect和getLocalVisibleRect
- poj 1218 THE DRUNK JAILER
- 面向对象
- Linux Shell脚本之自动修改IP
- LeetCode_59---Spiral Matrix II
- 2015.6.27_记录自己学到的和自己容易忘记的有关编写MapReduce程序的要点
- 3D点云配准与拼合
- 随手指拖动而变色的ScrollView
- POJ 1987 Distance Statistics (树上点分治)
- linux vi编辑常用命令
- 在Ubuntu 15.04下安装Android Studio
- oracle口令管理之允许某个用户最多尝试三次登录
- oracle口令管理之允许某个用户最多尝试三次登录
- leetcode 33 Search in Rotated Sorted Array