利用正则表达式匹配浮点型数据


Posted in Java/Android onMay 30, 2022

前言:

在开发中我们常常会使用到正则表达式,但很奇怪的是,每次你在使用正则表达式的时候你都发现你不会写,不知道语法,可能你大概还记得一部分,但很模糊,对于正则表达式的语法真心记不住,别的程序猿是不是我不清楚,但我是就是这样子,每次写都会发现记不住了,然后又去网上查找资料,又进行一次学习,慢慢的发现基本语法你又会了,但实际上你还是不会,可能是没有完全明白或者在实际开发中没有长期的使用导致,今天写这篇文章纯属唠嗑,其余的差不多都是复制粘贴了,另外说一下最近这一次翻开正则表达式去匹配浮点型数据做的一点思路,这一点和之前的是不一样的。以前写的正则去匹配浮点型的时候会发现无法完全正确的匹配,找了网上不少的高手或者菜鸟教程直接抄过来使用,发现其实都是有问题的,问题出在哪儿呢,大部分出现的问题都是在处理"0"和".“的情况下。你可能忘记了,我可以帮大家会议一下,当然大部分还是对的,但是如果出现以0开头的时候,你会发现,我可以输入n个0开头也能匹配出来,虽然有点会把连续的多个0开头的部分丢掉,但还是让人感觉匹配的不是很好,我有强迫症,这种匹配我认为是不正确的,另外就是”.",当你使用"."的时候,你会发现"xxxx."像这种格式的都能匹配,这是在逗我吗,难道这也算正确的,这种情况我会直接否认掉,但是在以往的开发中,我为了完后任务,当然也就不管了,没那么严格,对于上面出现的这几种情况我都心有不甘的默认了,毕竟开发需要的时间不能都花在搞这种问题上,时间那么有限,所以我当然就默许了这种问题的存在。今天呢又来搞了搞正则,还是相同的东西,我想自己写了,所以自己开搞了,废话有点多了,接下来就进入主题吧。

正则表达式

1、非负浮点型:(^[1-9]\d*\.\d+$|^0\.\d+$|^[1-9]\d*$|^0$)

2、浮点型:(^-?[1-9]\d*\.\d+$|^-?0\.\d+$|^-?[1-9]\d*$|^0$)

上面的正则是怎么写的呢?我来讲一讲

将浮点型数据做拆分,为啥要拆分呢,因为不拆分很难实现匹配浮点型字符串的正确格式

拆分成4类

1、非0开头的浮点型(123.12)
2、0开头的浮点型(0.12)
3、非0整数型
4、0

分别正则表达式

1、^[1-9]\d*\.\d+$
2、^0\.\d+$
3、^[1-9]\d*$
4、^0$

最后将4个表达式组合到一个中就得到最终的结果

(^[1-9]\d*\.\d+$|^0\.\d+$|^[1-9]\d*$|^0$)

浮点型是存在正负数的,所以还需要给得到的正则表达式添加符号

(^-?[1-9]\d*\.\d+$|^-?0\.\d+$|^-?[1-9]\d*$|^0$)

语法解析

符号 描述
^ 以什么开头
$ 以什么结尾
. 匹配任意非\n的单字符
\. 匹配.
+ 匹配一次或多次
* 匹配0次或多次
? 匹配0次或1次
x|y 表示匹配x或者y
{n} 表示匹配n次
[1-9] 表示范围1至9的任意1个数字
() 强制优先级,匹配括号需要在括号前加"\"
- 表示负号

Java代码

import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class RegexMatches {
	public static void main(String args[]) {
		String str = "";
		String pattern = "(^[1-9]\\d*\\.\\d+$|^0\\.\\d+$|^[1-9]\\d*$|^0$)";

		Pattern r = Pattern.compile(pattern);
		Matcher m = r.matcher(str);
		System.out.println(m.matches());
	}

}

附:正则表达式(同时匹配整型数和浮点数)

pattern="^[1-9]*[0-9]?(\.[0-9]{1,2})?$"

总结

到此这篇关于利用正则表达式匹配浮点型数据的文章就介绍到这了!


Tags in this post...

Java/Android 相关文章推荐
Springboot如何使用logback实现多环境配置?
Jun 16 Java/Android
浅谈什么是SpringBoot异常处理自动配置的原理
Jun 21 Java/Android
Springboot使用Spring Data JPA实现数据库操作
Jun 30 Java/Android
Sleuth+logback 设置traceid 及自定义信息方式
Jul 26 Java/Android
springboot 启动如何排除某些bean的注入
Aug 02 Java/Android
Java网络编程之UDP实现原理解析
Sep 04 Java/Android
springboot入门 之profile设置方式
Apr 04 Java/Android
Java8利用Stream对列表进行去除重复的方法详解
Apr 14 Java/Android
java版 简单三子棋游戏
May 04 Java/Android
SpringCloud超详细讲解Feign声明式服务调用
Jun 21 Java/Android
SpringBoot Http远程调用的方法
Aug 14 Java/Android
Java获取字符串编码格式实现思路
Sep 23 Java/Android
JavaScript正则表达式实现注册信息校验功能
May 30 #Java/Android
Java时间工具类Date的常用处理方法
May 25 #Java/Android
Java实现扫雷游戏详细代码讲解
多线程Spring通过@Scheduled实现定时任务
May 25 #Java/Android
SpringBoot全局异常处理方案分享
May 25 #Java/Android
Java数据结构之堆(优先队列)
May 20 #Java/Android
Java中Dijkstra(迪杰斯特拉)算法
You might like
php 常用类汇总 推荐收藏
2010/05/13 PHP
openPNE常用方法分享
2011/11/29 PHP
php实例分享之通过递归实现删除目录下的所有文件详解
2014/05/15 PHP
PHP图形操作之Jpgraph学习笔记
2015/12/25 PHP
laravel自定义分页效果
2017/07/23 PHP
jQuery源码分析-03构造jQuery对象-源码结构和核心函数
2011/11/14 Javascript
前台js改变Session的值(用ajax实现)
2012/12/28 Javascript
给Flash加一个超链接(推荐使用透明层)兼容主流浏览器
2013/06/09 Javascript
js setTimeout()函数介绍及应用以倒计时为例
2013/12/12 Javascript
深入浅出理解javaScript原型链
2015/05/09 Javascript
jQuery EasyUI框架中的Datagrid数据表格组件结构详解
2016/06/09 Javascript
React.js中常用的ES6写法总结(推荐)
2017/05/09 Javascript
简单的Vue SSR的示例代码
2018/01/12 Javascript
Vue 第三方字体图标引入 Font Awesome的方法
2018/09/28 Javascript
vue elementUI table 自定义表头和行合并的实例代码
2019/05/22 Javascript
Layui多选只有最后一个值的解决方法
2019/09/02 Javascript
Vue父组件向子组件传值以及data和props的区别详解
2020/03/02 Javascript
JavaScript Date对象功能与用法学习记录
2020/04/28 Javascript
[02:10]探秘浦东源深体育馆 DOTA2 Supermajor不见不散
2018/05/17 DOTA
Python list操作用法总结
2015/11/10 Python
Python爬虫番外篇之Cookie和Session详解
2017/12/27 Python
python中使用 xlwt 操作excel的常见方法与问题
2019/01/13 Python
详解python数据结构和算法
2019/04/18 Python
对python3.4 字符串转16进制的实例详解
2019/06/12 Python
如何利用Anaconda配置简单的Python环境
2019/06/24 Python
python实现吃苹果小游戏
2020/03/21 Python
Django数据库迁移常见使用方法
2020/11/12 Python
电子商务专业求职信
2014/03/08 职场文书
新品发布会主持词
2014/04/02 职场文书
区域销售主管岗位职责
2014/06/15 职场文书
个人剖析材料范文
2014/09/30 职场文书
就业意向协议书
2015/01/29 职场文书
《风娃娃》教学反思
2016/02/18 职场文书
妇联2016年六一国际儿童节活动总结
2016/04/06 职场文书
护理专业毕业自我鉴定
2019/08/12 职场文书
SQL优化老出错,那是你没弄明白MySQL解释计划用法
2021/11/27 MySQL