Java去掉小数点后面无效0的方案与建议

目录
  • 一:需求
  • 二:方案
    • 2.1 正则匹配
    • 2.2 BigDecimal
  • 三:测试
  • 四:建议

一:需求

当小数位很多的时候,小数位后面可能有一些多余的0并没有任何实际意义。所以在某些业务需求下可以去掉这些多余的0。例如:0.2000可以用0.2来表示。

二:方案

2.1 正则匹配

/**
     * 去掉给定字符串(小数)后面的无效0
     *
     * @param value 小数的字符串表示
     * @return 如果转换失败,返回null
     */
    public String convertByPattern(String value) {

        String regex = "^(-?\\d*)(\\.?0*)$";
        Matcher matcher = Pattern.compile(regex).matcher(value);
        if (matcher.find()) {
            return matcher.group(1);
        }
        String regex1 = "^(-?\\d*\\.\\d*[1-9])(0*)$";
        Matcher matcher1 = Pattern.compile(regex1).matcher(value);
        if (matcher1.find()) {
            return matcher1.group(1);
        }
        return null;
    }

当使用正则匹配的时候,需要代码中的两种正则表达式来进行匹配判断组合。第一种正则表达式用来匹配小数点后面全是0的值,例如122.000。第二种正则表达式用来匹配小数点后面存在非0数值的值,例如109.00200。

上述方法支持正数和负数的处理

在正则表达式中,使用分组的方式来实现,在正则匹配过程中,将要保留的部分放在第一个括号中,即组1,那么最终获取值的时候,就可以使用group(1)直接拿到

关于两个表达式:

表达式1:^(-?\d*)(\.?0*)$:

  -?:正负数的匹配均支持

  \d*:0个到n个数字,即匹配整数部分

  到这里,小数点前面部分就匹配完了,所以前面的部分可以作为第一组

  \.?:可以匹配0个或1个小数点

  0*:可以匹配0个或1个数值0

  第二个分组可有可无。因为表达式1主要使用用来识别出无小数点或者是小数点后面是若干个0的格式

表达式2:^(-?\d*\.\d*[1-9])(0*)$:

  -?:正负数的匹配均支持

  \d*:0个到n个数字,即匹配整数部分

  \.:匹配小数点

  \d*[1-9]:匹配小数部分,因为表达式2的目的是匹配小数点后面存在非0数值。那么[1-9]就是用来匹配最后一个非0数值的

  (0*) $:如果最后一个为是非0数值,那么不会匹配到任何。如果最后一位是0,那么这里匹配到的就是最后一个非0数值后面的所有0

2.2 BigDecimal

 /**
     * 通过将字符串(小数)转换为decimal
     * @param value 小数的字符串表示
     * @return
     */
    public String convertByBigDecimal(String value) {
        BigDecimal bigDecimal = new BigDecimal(value);
        BigDecimal bigDecimal1 = bigDecimal.stripTrailingZeros();
        return bigDecimal1.toPlainString();
    }

上述方法是将字符串转换为BigDecimal ,然后使用BigDecimal 原生方法stripTrailingZeros来去掉后面的无效0。同样的正负数均支持

三:测试

 public static void main(String[] args) {
        /**
         * (-)100
         * (-)123
         * (-)123.0000
         * (-)100.0000
         * (-)123.0
         * (-)100.0
         * (-)123.0900
         * (-)100.0900
         * (-)123.0009
         * (-)100.0009
         */
        List<String> strings = Arrays.asList("100", "-100",
                "123", "-123",
                "123.0000", "-123.0000",
                "100.0000", "-100.0000",
                "123.0", "-123.0",
                "100.0", "-100.0",
                "123.0900", "-123.0900",
                "100.0900", "-100.0900",
                "123.0009", "-123.0009",
                "100.0009", "-100.0009");
        for (String value : strings) {
            String s = new ZeroFormatTest2().convertByPattern(value);
            String s1 = new ZeroFormatTest2().convertByBigDecimal(value);
            System.out.println(s + "----" + s1);
        }
    }

结果输出:

100----100
-100-----100
123----123
-123-----123
123----123
-123-----123
100----100
-100-----100
123----123
-123-----123
100----100
-100-----100
123.09----123.09
-123.09-----123.09
100.09----100.09
-100.09-----100.09
123.0009----123.0009
-123.0009-----123.0009
100.0009----100.0009
-100.0009-----100.0009

四:建议

上述两种方法都可以实现我们的需求,但是从性能上面来讲,如果需要解析大量数据的时候,建议使用第一种,Pattern.compile(regex)可以是一个全局的,不需要每一条数据都实例化

到此这篇关于Java去掉小数点后面无效0的文章就介绍到这了,更多相关Java去掉小数点后面无效0内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Java使用正则表达式去除小数点后面多余的0功能示例

    本文实例讲述了Java使用正则表达式去除小数点后面多余的0功能.分享给大家供大家参考,具体如下: package test; /** * 去掉多余的.与0 * @author Hust * @Time 2011-11-7 */ public class TestString { public static void main(String[] args) { Float f = 1f; System.out.println(f.toString());//1.0 System.out.print

  • Java去掉小数点后面无效0的方案与建议

    目录 一:需求 二:方案 2.1 正则匹配 2.2 BigDecimal 三:测试 四:建议 一:需求 当小数位很多的时候,小数位后面可能有一些多余的0并没有任何实际意义.所以在某些业务需求下可以去掉这些多余的0.例如:0.2000可以用0.2来表示. 二:方案 2.1 正则匹配 /** * 去掉给定字符串(小数)后面的无效0 * * @param value 小数的字符串表示 * @return 如果转换失败,返回null */ public String convertByPattern(S

  • Java去掉数字字符串开头的0三种方法(推荐)

    方式一: 例如:"0000123" (字符串必须全为数字) 处理过程: String tempStr = "0000123"; int result = Integer.parseInt(tempStr); result 结果:123 方式二: 例如:"0000123" 处理过程: String str = "0000123"; String newStr = str.replaceFirst("^0*",

  • Java彻底消灭if-else的8种方案

    优化方案 1:提前 return,去除不必要的 else 如果 if-else 代码块包含 return 语句,可以考虑通过提前 return,把多余 else 干掉,使代码更加优雅. 优化前: if(condition){ //doSomething }else{ return ; } 优化后: if(!condition){ return ; } //doSomething 优化方案 2:使用条件三目运算符 使用条件三目运算符可以简化某些 if-else,使代码更加简洁,更具有可读性. 优化

  • 浅谈Java实现分布式事务的三种方案

    一.问题描述 用户支付完成会将支付状态及订单状态保存在订单数据库中,由订单服务去维护订单数据库.由库存服务去维护库存数据库的信息.下图是系统结构图: 如何实现两个分布式服务(订单服务.库存服务)共同完成一件事即订单支付成功自动减库存,这里的关键是如何保证两个分布式服务的事务的一致性. 尝试解决上边的需求,在订单服务中远程调用减库存接口,伪代码如下: 订单支付结果通知方法{ ​ 更新支付表中支付状态为"成功". ​ 远程调用减库存接口减库存. } 上边的逻辑说明: 1.更新支付表状态为本

  • java连不上mysql8.0问题的解决方法

    本文为大家分享了java连不上MySQL8.0问题集合,供大家参考,具体内容如下 问题1:Client does not support authentication protocol requested by Server:- 问题2:Unknown initial character set index '255' received from server- 问题3:MySQL8.0连接必要url语句 问题4:调用方法重复 运行问题1: 解决方法:(3句注意分号,wy123456是我数据库的

  • java实现时间控制的几种方案

    前言:最近小王同学又遇到了一个需求:线上的业务运行了一段时间,后来随着使用人数增多,出现了一个问题是这样的,一个订单会重复创建几次,导致数据库里出现了很多垃圾数据.在测试同学的不断测试下,发现问题出在了前端的一个提交按钮上,有的用户比较"着急",提交订单时候,一下子快速的点了5.6次(这手速没有几年是练不出来的,咳咳),导致请求一下子都涌进来,后端进行了重复处理.项目经理让小王优化这个点,绝对不能创建多次.还有一个需求是这样的,在与第三方对接过程中,对方提供了token进行时效性验证,

  • Java String.replace()方法"无效"的原因及解决方式

    首先我们来看个例子 public class Demo1 { public static void main(String[] args) { String aa="abcd"; aa.replace("a","f"); System.out.println("输出结果是"+aa); } } 运行结果是什么呢?我们先看看这个方法的api 返回一个新的字符串,用newChar替换此字符串中出现的所有oldChar 所以这里的结果

  • java中通过行为参数化传递代码方案

    目录 方案一 方案二 方案三 方案四 方案五 方案六 总结: 行为参数化:它意味着拿出一个代码块,把它准备好但是不执行,可以推迟该代码块的执行,比如将代码块作为参数,需要的时候再内部执行.下面我来通过例子来描述什么是行为参数化:现在来写一个有关筛选苹果的demo,现在农民伯伯想要筛选红色的苹果,可以这样来做: 方案一 public static List<Apple> filterGreenApples(List<Apple> inventory){ List<Apple&g

  • python 如何将浮点数尾部无效0去掉和无效的‘.’号

    方法一: a = 12.12300 #结果要求为12.123 b = 12.00 #结果为12 c = 200.12000 #结果为200.12 d = 200.0 #结果为200 print 'a==>' ,[ str (a), int (a)][ int (a) = = a] print 'b==>' ,[ str (b), int (b)][ int (b) = = b] print 'c==>' ,[ str (c), int (c)][ int (c) = = c] print

  • Java分布式锁的三种实现方案

    方案一:数据库乐观锁 乐观锁通常实现基于数据版本(version)的记录机制实现的,比如有一张红包表(t_bonus),有一个字段(left_count)记录礼物的剩余个数,用户每领取一个奖品,对应的left_count减1,在并发的情况下如何要保证left_count不为负数,乐观锁的实现方式为在红包表上添加一个版本号字段(version),默认为0. 异常实现流程 -- 可能会发生的异常情况 -- 线程1查询,当前left_count为1,则有记录 select * from t_bonus

随机推荐