博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
java 中的字符串处理--正则表达式
阅读量:5361 次
发布时间:2019-06-15

本文共 1149 字,大约阅读时间需要 3 分钟。

最近在做一些支付报文处理工作,需要从各种各样的报文中提取需要的信息比如(金额,订单号。。。),每个渠道报文各式各样,想要写一个通用的提取逻辑,于是就回顾java正则表达式的用法。当然我们可以自己写一些算法,去提取这些字段,但对于简单的解析来说,亲自手写算法有点杀鸡用牛刀的感觉,而且正则表达式完全可以满足大部分的字符提取需求。好了闲话不多说,先列出正则表达式的常用语法:

  • \:表示下一个字符为特殊含义的字符例如:\d匹配数字
  • ^:表示匹配字符开始的位置例如:^#.*:匹配以#开头的所有字符
  • $:表示匹配字符结束位置例如:.*元$:匹配以元为结尾的字符
  • .:表示匹配所有字符
  • *:表示出现次数为0,或大于0次
  • +:表示出现次数为1或大于1次
  • ?:表示匹配0次或1次
  • {n}:标示与字符刚好匹配n次
  • {n,m}:标示至少匹配n次,最多匹配m次
  • [xyz]:字符集,匹配字符集中任意字符,例如:[abc] 匹配plan中的a
  • [^xyz]:反向字符集,相当与非运算,表示不在字符集中的字符
  • (pattern):子表达式,在java中我们自左向右取group: matcher.group(0);

下面列出一些常用的特殊字符及其含义:

  • \d:匹配数字,等效于[0-9]
  • \D:匹配非数字,等效于[^0-9]
  • \n:匹配换行符
  • \r:匹配回车符
  • \s:匹配空格或者换行符或者换页符,等效于[\f\n\r\t\v]
  • \S:匹配任何非空字符
  • \w:匹配任何字类字符,等效于[a-zA-Z0-9]
  • \W:匹配任何非字类字符

为了加深理解与运用,下面列出几个应用场景:

取出下面字符串中的金额:

#支出合计:33笔, 共10.00元
String temp = "#支出合计:33笔, 共10.00元";        Pattern p = Pattern.compile("(\\d+\\.\\d+)");        Matcher matcher = p.matcher(temp);        if(matcher.find()){            System.out.println(matcher.group(0));            System.out.println(matcher.group(1));        }

输出:10.00

发现成功的将报文中的金额识别出来,因此我们只需要将不同结构的报文中含有金额部分输入,就可以方便的输出金额了,简单的万金油....

 

posted on
2017-09-14 14:21 阅读(
...) 评论(
...)

转载于:https://www.cnblogs.com/foreveravalon/p/7520445.html

你可能感兴趣的文章
Python学习week2-python介绍与pyenv安装
查看>>
php判断网页是否gzip压缩
查看>>
一个有意思的js实例,你会吗??[原创]
查看>>
sql server中bit字段实现取反操作
查看>>
Part3_lesson2---ARM指令分类学习
查看>>
jQuery拖拽原理实例
查看>>
JavaScript 技巧与高级特性
查看>>
Uva 11729 Commando War
查看>>
增强学习(一) ----- 基本概念
查看>>
ubuntu下USB连接Android手机
查看>>
C# 语句 分支语句 switch----case----.
查看>>
lseek函数
查看>>
反射获取 obj类 的属性 与对应值
查看>>
表单中的readonly与disable的区别(zhuan)
查看>>
win10下安装配置mysql-8.0.13--实战可用
查看>>
周记2018.8.27~9.2
查看>>
MySQL中 1305-FUNCTION liangshanhero2.getdate does not exit 问题解决
查看>>
Ctrl+Alt+Down/Up 按键冲突
查看>>
python序列化和json
查看>>
mongodb
查看>>