zoukankan      html  css  js  c++  java
  • 读取字符串中的数字和小数

    package com.jm.label.tools;

    import java.util.Map;
    import java.util.TreeMap;
    import java.util.regex.Matcher;
    import java.util.regex.Pattern;
    /**
     * 读取字符串中的数字和小数
     * @author JM.H
     *
     */
    public class DigitUtil {

        public static String getNumber(String str){
            Pattern p = Pattern.compile("(\d+)");
            Matcher m = p.matcher(str); String result = "";
            if (m.find()) {
                Map<Integer, String> map = new TreeMap<Integer, String>();
                Pattern p2 = Pattern.compile("(\d+\.\d+)");
                m = p2.matcher(str); //遍历小数部分
                while (m.find()) {
                    result = m.group(1) == null ? "" : m.group(1);
                    int i = str.indexOf(result);
                    String s = str.substring(i, i + result.length());
                    map.put(i, s); //排除小数的整数部分和另一个整数相同的情况下,寻找整数位置出现错误的可能,还有就是寻找重复的小数 // 例子中是排除第二个345.56时第一个345.56产生干扰和寻找整数345的位置时,前面的小数345.56会干扰
                    str = str.substring(0, i) + str.substring(i + result.length()); } //遍历整数
                Pattern p3 = Pattern.compile("(\d+)");
                m = p3.matcher(str);
                while (m.find()) {
                    result = m.group(1) == null ? "" : m.group(1); int i = str.indexOf(result); //排除jia567.23.23在第一轮过滤之后留下来的jia.23对整数23产生干扰
    //                System.out.println(String.valueOf(str.charAt(i)));
                    if (String.valueOf(str.charAt(i)).equals(".")) { //将这个字符串删除
                        str = str.substring(0, i - 1) + str.substring(i + result.length());
                        continue;
                    }
                    String s = str.substring(i, i + result.length());
                    map.put(i, s);
                    str = str.substring(0, i) + str.substring(i + result.length());
                }
                result = "";
                for (Map.Entry<Integer, String> e : map.entrySet()) {
                    result += e.getValue() + ",";
                }
                result = result.substring(0, result.length()-1);
            }
            else {
                result = "";
            }
    //        System.out.println(result);
            String[] split = result.split(","); //
            String resultRtr = split[split.length-1]; //
            return resultRtr;
        }
    }

  • 相关阅读:
    Linux Centos7(Mac) 安装Docker教程
    SpringBoot应用操作Rabbitmq(fanout广播高级操作)
    SpringBoot应用操作Rabbitmq(topic交换器高级操作)
    SpringBoot应用操作Rabbitmq(direct高级操作)
    CCF 字符串匹配(find()函数的使用)
    PKU 1204 Word Puzzles(AC自动机)
    PKU 1932 XYZZY(Floyd+Bellman||Spfa+Floyd)
    PKU 1201 Intervals(差分约束系统+Spfa)
    PKU 2352 Stars(裸一维树状数组)
    PKU 3169 Layout(差分约束系统+Bellman Ford)
  • 原文地址:https://www.cnblogs.com/java-h/p/10583986.html
Copyright © 2011-2022 走看看