阿拉伯转数字

package com.sf.gis.utils;

import java.util.ArrayList;
import java.util.List;
import java.util.Stack;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class StringNumUtils {

    public static int transferChineseNumber2ArabNumber(String chineseNumber) {
        String aval = "零一二三四五六七八九";
        String bval = "十百千万亿";
        int[] bnum = {10, 100, 1000, 10000, 100000000};
        int num = 0;
        char[] arr = chineseNumber.toCharArray();
        int len = arr.length;
        Stack<Integer> stack = new Stack<Integer>();
        for (int i = 0; i < len; i++) {
            char s = arr[i];
            //跳过零
            if(s == '零'){
                continue;
            }
            //用下标找到对应数字
            int index = bval.indexOf(s);
            //如果不在bval中,即当前字符为数字,直接入栈
            if(index == -1){
                stack.push(aval.indexOf(s));
            }else{ //当前字符为单位。
                int tempsum = 0;
                int val = bnum[index];
                //如果栈为空则直接入栈
                if(stack.isEmpty()){
                    stack.push(val);
                    continue;
                }
                //如果栈中有比val小的元素则出栈,累加,乘N,再入栈
                while(!stack.isEmpty() && stack.peek() < val){
                    tempsum += stack.pop();
                }
                //判断是否经过乘法处理
                if(tempsum == 0){
                    stack.push(val);
                }else{
                    stack.push(tempsum * val);
                }
            }
        }
        //计算最终的和
        while(!stack.isEmpty()){
            num += stack.pop();
        }
        return num;
    }

    public static String outputArabNumberString(String chineseNumberString){
        String reg = "[零一二三四五六七八九十百千万亿]+";
        Pattern pattern = Pattern.compile(reg);
        Matcher matcher = pattern.matcher(chineseNumberString);
        List<String> chineseNumbers = new ArrayList<>(16);
        List<Integer> arabNumbers = new ArrayList<>(16);
        boolean isNumberFirst = false;
        while(matcher.find()){
            chineseNumbers.add(matcher.group());
            // 转化成阿拉伯数字
            int arabNum = transferChineseNumber2ArabNumber(matcher.group());
            arabNumbers.add(arabNum);
        }
        String[] arrStr = chineseNumberString.split(reg);

        StringBuilder transferedNumber = new StringBuilder();

        // 数字的数量不大于文字的数量。
        // 如果结尾不是数字,则文字数量比数字数量多一(即使数字位于第一个也不会有影响);如果结尾是数字,则数字文本数量相等。
        for(int i =0 ;i<arrStr.length;i++){
            // 先拼文字再拼数字,即使数字在第一个也会存在一个空的字符串(""),先拼也不会有影响
            transferedNumber.append(arrStr[i]);
            if (i<arabNumbers.size()) {
                transferedNumber.append(arabNumbers.get(i));
            }
        }
        return transferedNumber.toString();
    }

    public static void main(String[] args) {
        String re0 = "[零一二三四五六七八九十百千]";
        String re1 = "\\d+-\\d+-?\\d*-?\\d*|"+re0+"+-"+re0+"+-?"+re0+"*-?"+re0+"*";//存在 3-3(3-3-3、3-3-3-3)
        String re2 = "\\d+号|"+re0+"+号";//存在3/三号
        String re3 = "\\d+-\\d+-?\\d*-?\\d*号|"+re0+"+-"+re0+"+-?"+re0+"*-?"+re0+"*号";//存在3-33-3(3-3-3、3-3-3-3)号
        String re4 = "\\d+号?[栋弄幢楼座]|"+re0+"+号?[栋弄幢楼座]";
        String re10 = "[省市乡县村屯区巷街路道]$";//以村等结尾
        String str1 = "香港吉祥二十号";
        System.out.println(re1);
        Pattern pattern = Pattern.compile(re2);
        Matcher matcher = pattern.matcher(str1);
        boolean rs = matcher.find();
        System.out.println(rs);
    }
}
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值