java常用工具类 数字工具类

本文实例为大家分享了java常用工具类,数字工具类的具体代码,供大家参考,具体内容如下

package com.jarvis.base.util;

import java.math.BigDecimal;
import java.text.DecimalFormat;
import java.text.NumberFormat;
import java.util.Random;

public class NumericHelper {

 /**
 * 描述:通过一个整数i获取你所要的哪几个(从0开始) i为 多个2的n次方之和,如i=7,那么根据原值是2的n次方之各,你的原值必定是1,2,4 。
 *
 * @param i
 *      数值
 * @return
 */
 public static int[] getWhich(long i) {
 int exp = Math.getExponent(i);
 if (i == (1 << (exp + 1)) - 1) {
  exp = exp + 1;
 }
 int[] num = new int[exp];
 int x = exp - 1;
 for (int n = 0; (1 << n) < i + 1; n++) {
  if ((1 << (n + 1)) > i && (1 << n) < (i + 1)) {
  num[x] = n;
  i -= 1 << n;
  n = 0;
  x--;
  }
 }
 return num;
 }

 /**
 * 描述:非四舍五入取整处理
 *
 * @param v
 *      需要四舍五入的数字
 * @return
 */
 public static int roundDown(double v) {
 BigDecimal b = new BigDecimal(Double.toString(v));
 BigDecimal one = new BigDecimal("1");
 return b.divide(one, 0, BigDecimal.ROUND_DOWN).intValue();
 }

 /**
 * 描述:四舍五入取整处理
 *
 * @param v
 *      需要四舍五入的数字
 * @return
 */
 public static int roundUp(double v) {
 BigDecimal b = new BigDecimal(Double.toString(v));
 BigDecimal one = new BigDecimal("1");
 return b.divide(one, 0, BigDecimal.ROUND_UP).intValue();
 }

 /**
 * 描述:提供精确的小数位四舍五入处理。
 *
 * @param v
 *      需要四舍五入的数字
 * @param scale
 *      小数点后保留几位
 * @return 四舍五入后的结果
 */
 public static double round(double v, int scale) {
 if (scale < 0) {
  throw new IllegalArgumentException("The scale must be a positive integer or zero");
 }

 BigDecimal b = new BigDecimal(Double.toString(v));
 BigDecimal one = new BigDecimal("1");
 return b.divide(one, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
 }

 /**
 * 描述:四舍五入保留两位小数
 *
 * @param num
 *      数字
 * @return 保留两位小数的数字字串
 */
 public static String format(double num) {
 return format(num, "0.00");
 }

 /**
 * 描述:四舍五入数字保留小数位
 *
 * @param num
 *      数字
 * @param digits
 *      小数位
 * @return
 */
 public static String format(double num, int digits) {
 String pattern = "0";
 if (digits > 0) {
  pattern += "." + createStr("0", digits, "");
 }
 return format(num, pattern);
 }

 /**
 * 描述:生成字符串
 *
 * @param arg0
 *      字符串元素
 * @param arg1
 *      生成个数
 * @param arg2
 *      间隔符号
 * @return
 */
 private static String createStr(String arg0, int arg1, String arg2) {
 if (arg0 == null) {
  return "";
 } else {
  StringBuffer sb = new StringBuffer();
  for (int i = 0; i < arg1; i++) {
  if (arg2 == null)
   arg2 = "";
  sb.append(arg0).append(arg2);
  }
  if (sb.length() > 0) {
  sb.delete(sb.lastIndexOf(arg2), sb.length());
  }

  return sb.toString();
 }
 }

 /**
 * 描述:数字格式化
 *
 * @param num
 *      数字
 * @param pattern
 *      格式
 * @return
 */
 public static String format(double num, String pattern) {
 NumberFormat fmt = null;
 if (pattern != null && pattern.length() > 0) {
  fmt = new DecimalFormat(pattern);
 } else {
  fmt = new DecimalFormat();
 }
 return fmt.format(num);
 }

 /**
 * 求浮点数的权重
 *
 * @param number
 * @return
 */
 public static double weight(double number) {
 if (number == 0) {
  return 1;
 }

 double e = Math.log10(Math.abs(number));
 int n = Double.valueOf(Math.floor(e)).intValue();
 double weight = 1;
 if (n > 0) {
  for (int i = 0; i < n; i++) {
  weight *= 10;
  }
 } else {
  for (int i = 0; i > n; i--) {
  weight /= 10;
  }
 }
 return weight;
 }

 /**
 * 获得权重的单位
 *
 * @param scale
 * @return
 */
 public static String unit(double scale) {
 if (scale == 1 || scale == 0) {
  return "";// 不设置单位倍率单位,使用基准单位
 }
 String[] units = new String[] { "十", "百", "千", "万", "十万", "百万", "千万", "亿", "十亿", "百亿", "千亿", "兆" };
 String[] units2 = new String[] { "十分", "百分", "千分", "万分", "十万分", "百万分", "千万分" };
 double e = Math.log10(scale);
 int position = Double.valueOf(Math.ceil(e)).intValue();
 if (position >= 1 && position <= units.length) {
  return units[position - 1];
 } else if (position <= -1 && -position <= units2.length) {
  return units2[-position - 1];
 } else {
  return "无量";
 }
 }

 /**
 * 获得浮点数的缩放比例
 *
 * @param num
 * @return
 */
 public static double scale(double num) {
 double absValue = Math.abs(num);
 // 无需缩放
 if (absValue < 10000 && absValue >= 1) {
  return 1;
 }
 // 无需缩放
 else if (absValue < 1 && absValue > 0.0001) {
  return 1;
 } else {
  return weight(num) / 10;
 }
 }

 /**
 * 获得缩放后并且格式化的浮点数
 *
 * @param num
 * @param scale
 * @return
 */
 public static double scaleNumber(double num, double scale) {
 DecimalFormat df = null;
 if (scale == 1) {
  df = new DecimalFormat("#.0000");
 } else {
  df = new DecimalFormat("#.00");
 }
 double scaledNum = num / scale;
 return Double.valueOf(df.format(scaledNum));
 }

 /**
 * 产生n位随机数 TODO:性能不要,有待优化
 */
 public static String ramdomNumber(int n) {
 if (n <= 0) {
  throw new IllegalArgumentException("n must be positive !");
 }
 Random random = new Random();
 StringBuilder result = new StringBuilder();
 for (int i = 0; i < n; i++) {
  result.append(random.nextInt(10));
 }
 return result.toString();
 }

 /**
 * 缩放1W倍
 */
 public static double changeTo(double number) {
 boolean flag = false;
 if (number < 0) {
  flag = true;
 }
 double value = Math.abs(number);
 value = value / 10000.0;
 if (flag) {
  value = Double.parseDouble("-" + value);
 }
 return value;
 }

 /**
 *
 * 描述:缩放比例
 *
 * @param number
 * @param scale
 * @param points
 * @return
 */
 public static String scaleNumberToStr(double number, double scale, int points) {
 boolean flag = (number < 0);
 number = Math.abs(number);
 String result = "";
 DecimalFormat nbf3 = (DecimalFormat) NumberFormat.getInstance();// 默认格式
 nbf3.setGroupingUsed(false);
 nbf3.setMinimumFractionDigits(points);
 nbf3.setMaximumFractionDigits(points);
 double scaledNum = number / scale;
 result = nbf3.format(scaledNum);
 if (flag) {
  result = "-" + result;
 }
 return result;
 }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Java中StringUtils工具类的一些用法实例

    StringUtils 方法的操作对象是 java.lang.String 类型的对象,是 JDK 提供的 String 类型操作方法的补充,并且是 null 安全的(即如果输入参数 String 为 null 则不会抛出 NullPointerException ,而是做了相应处理,例如,如果输入为 null 则返回也是 null 等,具体可以查看源代码). 除了构造器,StringUtils 中一共有130多个方法,并且都是 static 的,所以我们可以这样调用 StringUtils.x

  • java连接数据库增、删、改、查工具类

    java连接数据库增.删.改.查工具类 数据库操作工具类,因为各厂家数据库的分页条件不同,目前支持Mysql.Oracle.Postgresql的分页查询在Postgresql环境测试过了,其他数据库未测试.sql语句需要使用预编译形式的 复制代码 代码如下: package db; import java.lang.annotation.ElementType;import java.lang.annotation.Retention;import java.lang.annotation.R

  • java使用jdbc连接数据库工具类和jdbc连接mysql数据示例

    这个工具类使用简单,实例化直接调用就可以了,大家还可以方便的根据自己的需要在里面增加自己的功能 复制代码 代码如下: package com.lanp.ajax.db; import java.sql.Connection;import java.sql.DriverManager;import java.sql.PreparedStatement;import java.sql.ResultSet;import java.sql.SQLException; /** * 连接数据库的工具类,被定

  • java常用工具类之Excel操作类及依赖包下载

    依赖包下载:http://xiazai.jb51.net/201407/tools/java-excel-dependency(jb51.net).rar Excel工具类ExcelUtil.java源码: package com.itjh.javaUtil; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStr

  • Java常用数字工具类 数字转汉字(1)

    本人是从事互联网金融行业的,所以会接触到一些金融类的问题,常见的一种就是数字转汉字大小写的问题.所以抽空就写了一个小小的工具类,实现了数字转汉字.大数相加.相减.相乘的工具类,希望能帮助有需求的同行们.本篇就分享一下数字转化为汉字的思路吧. 数字转汉字的原理: 拆分:由于整数部分要加权值,而小数部分直接转换即可,所以首先要将数字拆分成整数+小数: 整数处理:按照我们的中国人的习惯,把数字格式化成4位一组,不足4位前面补0.每次处理4位,按位匹配数组中的汉字+权值.即按照数值找数字数组(num_l

  • java实现excel导入数据的工具类

    导入Excel数据的工具类,调用也就几行代码,很简单的. 复制代码 代码如下: import jxl.Cell;import jxl.Sheet;import jxl.Workbook;import jxl.read.biff.BiffException;import org.apache.commons.beanutils.BeanUtils;import org.slf4j.Logger;import org.slf4j.LoggerFactory; import java.io.IOExc

  • java正则表达式表单验证类工具类(验证邮箱、手机号码、qq号码等)

    java使用正则表达式进行表单验证工具类,可以验证邮箱.手机号码.qq号码等 复制代码 代码如下: package util; import java.util.regex.Matcher;import java.util.regex.Pattern; /** * 使用正则表达式进行表单验证 *  */ public class RegexValidateUtil {    static boolean flag = false;    static String regex = ""

  • java文件操作工具类分享(file文件工具类)

    复制代码 代码如下: import java.io.BufferedInputStream;import java.io.BufferedOutputStream;import java.io.BufferedReader;import java.io.File;import java.io.FileInputStream;import java.io.FileNotFoundException;import java.io.FileOutputStream;import java.io.Fil

  • java常用工具类之数据库连接类(可以连接多种数据库)

    依赖包下载:http://xiazai.jb51.net/201407/tools/java-db-dependency(jb51.net).rar 数据库连接类源码: package com.itjh.javaUtil; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.R

  • java常用工具类之DES和Base64加密解密类

    一.DES加密和解密 package com.itjh.javaUtil; import java.io.UnsupportedEncodingException; import java.security.InvalidKeyException; import java.security.NoSuchAlgorithmException; import java.security.SecureRandom; import java.security.spec.InvalidKeySpecExc

随机推荐