zoukankan      html  css  js  c++  java
  • java人民币大小写转换方法

      1. [代码]java人民币大小写转换方法

      /**

      * 人民币转成大写

      *

      * @param value

      * @return String

      public static String hangeToBig(double value)

      {

      char[] hunit = { '拾', '佰', '仟' }; // 段内位置表示

      char[] vunit = { '万', '亿' }; // 段名表示

      char[] digit = { '零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖' }; // 数字表示

      long midVal = (long) (value * 100); // 转化成整形

      String valStr = String.valueOf(midVal); // 转化成字符串

      String head = valStr.substring(0, valStr.length() - 2); // 取整数部分

      String rail = valStr.substring(valStr.length() - 2); // 取小数部分

      String prefix = ""; // 整数部分转化的结果

      String suffix = ""; // 小数部分转化的结果

      处理小数点后面的java培训

      if (rail.equals("00"))

      { // 如果小数部分为0

      suffix = "整";

      }

      else

      {

      suffix = digit[rail.charAt(0) - '0'] + "角" + digit[rail.charAt(1) - '0'] + "分"; // 否则把角分转化出来

      }

      // 处理小数点前面的数

      char[] chDig = head.toCharArray(); // 把整数部分转化成字符数组

      char zero = '0'; // 标志'0'表示出现过0

      byte zeroSerNum = 0; // 连续出现0的次数

      for (int i = 0; i < chDig.length; i++)

      { // 循环处理每个数字

      int idx = (chDig.length - i - 1) % 4; // 取段内位置

      int vidx = (chDig.length - i - 1) / 4; // 取段位置

      if (chDig[i] == '0')

      { // 如果当前字符是0

      zeroSerNum++; // 连续0次数递增

      if (zero == '0')

      { // 标志

      zero = digit[0];

      }

      else if (idx == 0 && vidx > 0 && zeroSerNum < 4)

      {

      prefix += vunit[vidx - 1];

      zero = '0';

      }

      continue;

      }

      zeroSerNum = 0; // 连续0次数清零

      if (zero != '0')

      { // 如果标志不为0,则加上,例如万,亿什么的

      prefix += zero;

      zero = '0';

      }

      prefix += digit[chDig[i] - '0']; // 转化该数字表示

      if (idx > 0)

      prefix += hunit[idx - 1];

      if (idx == 0 && vidx > 0)

      {

      prefix += vunit[vidx - 1]; // 段结束位置应该加上段名如万,亿

      }

      }

      if (prefix.length() > 0)

      prefix += '圆'; // 如果整数部分存在,则有圆的字样

      return prefix + suffix; // 返回正确表示

      }

      

  • 相关阅读:
    Coursera课程《Python数据结构》中课件
    Coursera课程《Python数据结构》中课程目录
    Coursera课程《大家的编程》(Python入门)中课程目录
    Python for everyone chapter 1
    Coursera课程《大家的python》(Python for everyone)课件
    Coursera课程《大家的Python》中一些资料
    局部敏感哈希 Kernelized Locality-Sensitive Hashing Page
    CVPR14 图像检索papers
    Sequential projection learning for hashing阅读笔记
    Hashing图像检索源码及数据库总结
  • 原文地址:https://www.cnblogs.com/gojava/p/3522492.html
Copyright © 2011-2022 走看看