|  | @@ -1,999 +0,0 @@
 | 
	
		
			
				|  |  | -package com.ruoyi.common.utils.text;
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -import java.math.BigDecimal;
 | 
	
		
			
				|  |  | -import java.math.BigInteger;
 | 
	
		
			
				|  |  | -import java.nio.ByteBuffer;
 | 
	
		
			
				|  |  | -import java.nio.charset.Charset;
 | 
	
		
			
				|  |  | -import java.text.NumberFormat;
 | 
	
		
			
				|  |  | -import java.util.Set;
 | 
	
		
			
				|  |  | -import com.ruoyi.common.utils.StringUtils;
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -/**
 | 
	
		
			
				|  |  | - * 类型转换器
 | 
	
		
			
				|  |  | - * 
 | 
	
		
			
				|  |  | - * @author ruoyi
 | 
	
		
			
				|  |  | - */
 | 
	
		
			
				|  |  | -public class Convert
 | 
	
		
			
				|  |  | -{
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为字符串<br>
 | 
	
		
			
				|  |  | -     * 如果给定的值为null,或者转换失败,返回默认值<br>
 | 
	
		
			
				|  |  | -     * 转换失败不会报错
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param value 被转换的值
 | 
	
		
			
				|  |  | -     * @param defaultValue 转换错误时的默认值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static String toStr(Object value, String defaultValue)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        if (null == value)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        if (value instanceof String)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return (String) value;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        return value.toString();
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为字符串<br>
 | 
	
		
			
				|  |  | -     * 如果给定的值为<code>null</code>,或者转换失败,返回默认值<code>null</code><br>
 | 
	
		
			
				|  |  | -     * 转换失败不会报错
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param value 被转换的值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static String toStr(Object value)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        return toStr(value, null);
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为字符<br>
 | 
	
		
			
				|  |  | -     * 如果给定的值为null,或者转换失败,返回默认值<br>
 | 
	
		
			
				|  |  | -     * 转换失败不会报错
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param value 被转换的值
 | 
	
		
			
				|  |  | -     * @param defaultValue 转换错误时的默认值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static Character toChar(Object value, Character defaultValue)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        if (null == value)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        if (value instanceof Character)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return (Character) value;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        final String valueStr = toStr(value, null);
 | 
	
		
			
				|  |  | -        return StringUtils.isEmpty(valueStr) ? defaultValue : valueStr.charAt(0);
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为字符<br>
 | 
	
		
			
				|  |  | -     * 如果给定的值为<code>null</code>,或者转换失败,返回默认值<code>null</code><br>
 | 
	
		
			
				|  |  | -     * 转换失败不会报错
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param value 被转换的值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static Character toChar(Object value)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        return toChar(value, null);
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为byte<br>
 | 
	
		
			
				|  |  | -     * 如果给定的值为<code>null</code>,或者转换失败,返回默认值<br>
 | 
	
		
			
				|  |  | -     * 转换失败不会报错
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param value 被转换的值
 | 
	
		
			
				|  |  | -     * @param defaultValue 转换错误时的默认值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static Byte toByte(Object value, Byte defaultValue)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        if (value == null)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        if (value instanceof Byte)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return (Byte) value;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        if (value instanceof Number)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return ((Number) value).byteValue();
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        final String valueStr = toStr(value, null);
 | 
	
		
			
				|  |  | -        if (StringUtils.isEmpty(valueStr))
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        try
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return Byte.parseByte(valueStr);
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        catch (Exception e)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为byte<br>
 | 
	
		
			
				|  |  | -     * 如果给定的值为<code>null</code>,或者转换失败,返回默认值<code>null</code><br>
 | 
	
		
			
				|  |  | -     * 转换失败不会报错
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param value 被转换的值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static Byte toByte(Object value)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        return toByte(value, null);
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为Short<br>
 | 
	
		
			
				|  |  | -     * 如果给定的值为<code>null</code>,或者转换失败,返回默认值<br>
 | 
	
		
			
				|  |  | -     * 转换失败不会报错
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param value 被转换的值
 | 
	
		
			
				|  |  | -     * @param defaultValue 转换错误时的默认值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static Short toShort(Object value, Short defaultValue)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        if (value == null)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        if (value instanceof Short)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return (Short) value;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        if (value instanceof Number)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return ((Number) value).shortValue();
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        final String valueStr = toStr(value, null);
 | 
	
		
			
				|  |  | -        if (StringUtils.isEmpty(valueStr))
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        try
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return Short.parseShort(valueStr.trim());
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        catch (Exception e)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为Short<br>
 | 
	
		
			
				|  |  | -     * 如果给定的值为<code>null</code>,或者转换失败,返回默认值<code>null</code><br>
 | 
	
		
			
				|  |  | -     * 转换失败不会报错
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param value 被转换的值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static Short toShort(Object value)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        return toShort(value, null);
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为Number<br>
 | 
	
		
			
				|  |  | -     * 如果给定的值为空,或者转换失败,返回默认值<br>
 | 
	
		
			
				|  |  | -     * 转换失败不会报错
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param value 被转换的值
 | 
	
		
			
				|  |  | -     * @param defaultValue 转换错误时的默认值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static Number toNumber(Object value, Number defaultValue)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        if (value == null)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        if (value instanceof Number)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return (Number) value;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        final String valueStr = toStr(value, null);
 | 
	
		
			
				|  |  | -        if (StringUtils.isEmpty(valueStr))
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        try
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return NumberFormat.getInstance().parse(valueStr);
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        catch (Exception e)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为Number<br>
 | 
	
		
			
				|  |  | -     * 如果给定的值为空,或者转换失败,返回默认值<code>null</code><br>
 | 
	
		
			
				|  |  | -     * 转换失败不会报错
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param value 被转换的值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static Number toNumber(Object value)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        return toNumber(value, null);
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为int<br>
 | 
	
		
			
				|  |  | -     * 如果给定的值为空,或者转换失败,返回默认值<br>
 | 
	
		
			
				|  |  | -     * 转换失败不会报错
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param value 被转换的值
 | 
	
		
			
				|  |  | -     * @param defaultValue 转换错误时的默认值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static Integer toInt(Object value, Integer defaultValue)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        if (value == null)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        if (value instanceof Integer)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return (Integer) value;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        if (value instanceof Number)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return ((Number) value).intValue();
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        final String valueStr = toStr(value, null);
 | 
	
		
			
				|  |  | -        if (StringUtils.isEmpty(valueStr))
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        try
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return Integer.parseInt(valueStr.trim());
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        catch (Exception e)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为int<br>
 | 
	
		
			
				|  |  | -     * 如果给定的值为<code>null</code>,或者转换失败,返回默认值<code>null</code><br>
 | 
	
		
			
				|  |  | -     * 转换失败不会报错
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param value 被转换的值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static Integer toInt(Object value)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        return toInt(value, null);
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为Integer数组<br>
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param str 被转换的值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static Integer[] toIntArray(String str)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        return toIntArray(",", str);
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为Long数组<br>
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param str 被转换的值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static Long[] toLongArray(String str)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        return toLongArray(",", str);
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为Integer数组<br>
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param split 分隔符
 | 
	
		
			
				|  |  | -     * @param split 被转换的值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static Integer[] toIntArray(String split, String str)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        if (StringUtils.isEmpty(str))
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return new Integer[] {};
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        String[] arr = str.split(split);
 | 
	
		
			
				|  |  | -        final Integer[] ints = new Integer[arr.length];
 | 
	
		
			
				|  |  | -        for (int i = 0; i < arr.length; i++)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            final Integer v = toInt(arr[i], 0);
 | 
	
		
			
				|  |  | -            ints[i] = v;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        return ints;
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为Long数组<br>
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param split 分隔符
 | 
	
		
			
				|  |  | -     * @param str 被转换的值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static Long[] toLongArray(String split, String str)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        if (StringUtils.isEmpty(str))
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return new Long[] {};
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        String[] arr = str.split(split);
 | 
	
		
			
				|  |  | -        final Long[] longs = new Long[arr.length];
 | 
	
		
			
				|  |  | -        for (int i = 0; i < arr.length; i++)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            final Long v = toLong(arr[i], null);
 | 
	
		
			
				|  |  | -            longs[i] = v;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        return longs;
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为String数组<br>
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param str 被转换的值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static String[] toStrArray(String str)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        return toStrArray(",", str);
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为String数组<br>
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param split 分隔符
 | 
	
		
			
				|  |  | -     * @param split 被转换的值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static String[] toStrArray(String split, String str)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        return str.split(split);
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为long<br>
 | 
	
		
			
				|  |  | -     * 如果给定的值为空,或者转换失败,返回默认值<br>
 | 
	
		
			
				|  |  | -     * 转换失败不会报错
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param value 被转换的值
 | 
	
		
			
				|  |  | -     * @param defaultValue 转换错误时的默认值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static Long toLong(Object value, Long defaultValue)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        if (value == null)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        if (value instanceof Long)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return (Long) value;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        if (value instanceof Number)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return ((Number) value).longValue();
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        final String valueStr = toStr(value, null);
 | 
	
		
			
				|  |  | -        if (StringUtils.isEmpty(valueStr))
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        try
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            // 支持科学计数法
 | 
	
		
			
				|  |  | -            return new BigDecimal(valueStr.trim()).longValue();
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        catch (Exception e)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为long<br>
 | 
	
		
			
				|  |  | -     * 如果给定的值为<code>null</code>,或者转换失败,返回默认值<code>null</code><br>
 | 
	
		
			
				|  |  | -     * 转换失败不会报错
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param value 被转换的值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static Long toLong(Object value)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        return toLong(value, null);
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为double<br>
 | 
	
		
			
				|  |  | -     * 如果给定的值为空,或者转换失败,返回默认值<br>
 | 
	
		
			
				|  |  | -     * 转换失败不会报错
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param value 被转换的值
 | 
	
		
			
				|  |  | -     * @param defaultValue 转换错误时的默认值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static Double toDouble(Object value, Double defaultValue)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        if (value == null)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        if (value instanceof Double)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return (Double) value;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        if (value instanceof Number)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return ((Number) value).doubleValue();
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        final String valueStr = toStr(value, null);
 | 
	
		
			
				|  |  | -        if (StringUtils.isEmpty(valueStr))
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        try
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            // 支持科学计数法
 | 
	
		
			
				|  |  | -            return new BigDecimal(valueStr.trim()).doubleValue();
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        catch (Exception e)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为double<br>
 | 
	
		
			
				|  |  | -     * 如果给定的值为空,或者转换失败,返回默认值<code>null</code><br>
 | 
	
		
			
				|  |  | -     * 转换失败不会报错
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param value 被转换的值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static Double toDouble(Object value)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        return toDouble(value, null);
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为Float<br>
 | 
	
		
			
				|  |  | -     * 如果给定的值为空,或者转换失败,返回默认值<br>
 | 
	
		
			
				|  |  | -     * 转换失败不会报错
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param value 被转换的值
 | 
	
		
			
				|  |  | -     * @param defaultValue 转换错误时的默认值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static Float toFloat(Object value, Float defaultValue)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        if (value == null)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        if (value instanceof Float)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return (Float) value;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        if (value instanceof Number)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return ((Number) value).floatValue();
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        final String valueStr = toStr(value, null);
 | 
	
		
			
				|  |  | -        if (StringUtils.isEmpty(valueStr))
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        try
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return Float.parseFloat(valueStr.trim());
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        catch (Exception e)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为Float<br>
 | 
	
		
			
				|  |  | -     * 如果给定的值为空,或者转换失败,返回默认值<code>null</code><br>
 | 
	
		
			
				|  |  | -     * 转换失败不会报错
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param value 被转换的值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static Float toFloat(Object value)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        return toFloat(value, null);
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为boolean<br>
 | 
	
		
			
				|  |  | -     * String支持的值为:true、false、yes、ok、no,1,0 如果给定的值为空,或者转换失败,返回默认值<br>
 | 
	
		
			
				|  |  | -     * 转换失败不会报错
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param value 被转换的值
 | 
	
		
			
				|  |  | -     * @param defaultValue 转换错误时的默认值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static Boolean toBool(Object value, Boolean defaultValue)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        if (value == null)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        if (value instanceof Boolean)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return (Boolean) value;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        String valueStr = toStr(value, null);
 | 
	
		
			
				|  |  | -        if (StringUtils.isEmpty(valueStr))
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        valueStr = valueStr.trim().toLowerCase();
 | 
	
		
			
				|  |  | -        switch (valueStr)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            case "true":
 | 
	
		
			
				|  |  | -                return true;
 | 
	
		
			
				|  |  | -            case "false":
 | 
	
		
			
				|  |  | -                return false;
 | 
	
		
			
				|  |  | -            case "yes":
 | 
	
		
			
				|  |  | -                return true;
 | 
	
		
			
				|  |  | -            case "ok":
 | 
	
		
			
				|  |  | -                return true;
 | 
	
		
			
				|  |  | -            case "no":
 | 
	
		
			
				|  |  | -                return false;
 | 
	
		
			
				|  |  | -            case "1":
 | 
	
		
			
				|  |  | -                return true;
 | 
	
		
			
				|  |  | -            case "0":
 | 
	
		
			
				|  |  | -                return false;
 | 
	
		
			
				|  |  | -            default:
 | 
	
		
			
				|  |  | -                return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为boolean<br>
 | 
	
		
			
				|  |  | -     * 如果给定的值为空,或者转换失败,返回默认值<code>null</code><br>
 | 
	
		
			
				|  |  | -     * 转换失败不会报错
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param value 被转换的值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static Boolean toBool(Object value)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        return toBool(value, null);
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为Enum对象<br>
 | 
	
		
			
				|  |  | -     * 如果给定的值为空,或者转换失败,返回默认值<br>
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param clazz Enum的Class
 | 
	
		
			
				|  |  | -     * @param value 值
 | 
	
		
			
				|  |  | -     * @param defaultValue 默认值
 | 
	
		
			
				|  |  | -     * @return Enum
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static <E extends Enum<E>> E toEnum(Class<E> clazz, Object value, E defaultValue)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        if (value == null)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        if (clazz.isAssignableFrom(value.getClass()))
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            @SuppressWarnings("unchecked")
 | 
	
		
			
				|  |  | -            E myE = (E) value;
 | 
	
		
			
				|  |  | -            return myE;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        final String valueStr = toStr(value, null);
 | 
	
		
			
				|  |  | -        if (StringUtils.isEmpty(valueStr))
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        try
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return Enum.valueOf(clazz, valueStr);
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        catch (Exception e)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为Enum对象<br>
 | 
	
		
			
				|  |  | -     * 如果给定的值为空,或者转换失败,返回默认值<code>null</code><br>
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param clazz Enum的Class
 | 
	
		
			
				|  |  | -     * @param value 值
 | 
	
		
			
				|  |  | -     * @return Enum
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static <E extends Enum<E>> E toEnum(Class<E> clazz, Object value)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        return toEnum(clazz, value, null);
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为BigInteger<br>
 | 
	
		
			
				|  |  | -     * 如果给定的值为空,或者转换失败,返回默认值<br>
 | 
	
		
			
				|  |  | -     * 转换失败不会报错
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param value 被转换的值
 | 
	
		
			
				|  |  | -     * @param defaultValue 转换错误时的默认值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static BigInteger toBigInteger(Object value, BigInteger defaultValue)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        if (value == null)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        if (value instanceof BigInteger)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return (BigInteger) value;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        if (value instanceof Long)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return BigInteger.valueOf((Long) value);
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        final String valueStr = toStr(value, null);
 | 
	
		
			
				|  |  | -        if (StringUtils.isEmpty(valueStr))
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        try
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return new BigInteger(valueStr);
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        catch (Exception e)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为BigInteger<br>
 | 
	
		
			
				|  |  | -     * 如果给定的值为空,或者转换失败,返回默认值<code>null</code><br>
 | 
	
		
			
				|  |  | -     * 转换失败不会报错
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param value 被转换的值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static BigInteger toBigInteger(Object value)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        return toBigInteger(value, null);
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为BigDecimal<br>
 | 
	
		
			
				|  |  | -     * 如果给定的值为空,或者转换失败,返回默认值<br>
 | 
	
		
			
				|  |  | -     * 转换失败不会报错
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param value 被转换的值
 | 
	
		
			
				|  |  | -     * @param defaultValue 转换错误时的默认值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static BigDecimal toBigDecimal(Object value, BigDecimal defaultValue)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        if (value == null)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        if (value instanceof BigDecimal)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return (BigDecimal) value;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        if (value instanceof Long)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return new BigDecimal((Long) value);
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        if (value instanceof Double)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return new BigDecimal((Double) value);
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        if (value instanceof Integer)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return new BigDecimal((Integer) value);
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        final String valueStr = toStr(value, null);
 | 
	
		
			
				|  |  | -        if (StringUtils.isEmpty(valueStr))
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        try
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return new BigDecimal(valueStr);
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        catch (Exception e)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return defaultValue;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 转换为BigDecimal<br>
 | 
	
		
			
				|  |  | -     * 如果给定的值为空,或者转换失败,返回默认值<br>
 | 
	
		
			
				|  |  | -     * 转换失败不会报错
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param value 被转换的值
 | 
	
		
			
				|  |  | -     * @return 结果
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static BigDecimal toBigDecimal(Object value)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        return toBigDecimal(value, null);
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 将对象转为字符串<br>
 | 
	
		
			
				|  |  | -     * 1、Byte数组和ByteBuffer会被转换为对应字符串的数组 2、对象数组会调用Arrays.toString方法
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param obj 对象
 | 
	
		
			
				|  |  | -     * @return 字符串
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static String utf8Str(Object obj)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        return str(obj, CharsetKit.CHARSET_UTF_8);
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 将对象转为字符串<br>
 | 
	
		
			
				|  |  | -     * 1、Byte数组和ByteBuffer会被转换为对应字符串的数组 2、对象数组会调用Arrays.toString方法
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param obj 对象
 | 
	
		
			
				|  |  | -     * @param charsetName 字符集
 | 
	
		
			
				|  |  | -     * @return 字符串
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static String str(Object obj, String charsetName)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        return str(obj, Charset.forName(charsetName));
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 将对象转为字符串<br>
 | 
	
		
			
				|  |  | -     * 1、Byte数组和ByteBuffer会被转换为对应字符串的数组 2、对象数组会调用Arrays.toString方法
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param obj 对象
 | 
	
		
			
				|  |  | -     * @param charset 字符集
 | 
	
		
			
				|  |  | -     * @return 字符串
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static String str(Object obj, Charset charset)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        if (null == obj)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return null;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        if (obj instanceof String)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return (String) obj;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        else if (obj instanceof byte[] || obj instanceof Byte[])
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return str((Byte[]) obj, charset);
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        else if (obj instanceof ByteBuffer)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return str((ByteBuffer) obj, charset);
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        return obj.toString();
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 将byte数组转为字符串
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param bytes byte数组
 | 
	
		
			
				|  |  | -     * @param charset 字符集
 | 
	
		
			
				|  |  | -     * @return 字符串
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static String str(byte[] bytes, String charset)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        return str(bytes, StringUtils.isEmpty(charset) ? Charset.defaultCharset() : Charset.forName(charset));
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 解码字节码
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param data 字符串
 | 
	
		
			
				|  |  | -     * @param charset 字符集,如果此字段为空,则解码的结果取决于平台
 | 
	
		
			
				|  |  | -     * @return 解码后的字符串
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static String str(byte[] data, Charset charset)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        if (data == null)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return null;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        if (null == charset)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return new String(data);
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        return new String(data, charset);
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 将编码的byteBuffer数据转换为字符串
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param data 数据
 | 
	
		
			
				|  |  | -     * @param charset 字符集,如果为空使用当前系统字符集
 | 
	
		
			
				|  |  | -     * @return 字符串
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static String str(ByteBuffer data, String charset)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        if (data == null)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            return null;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        return str(data, Charset.forName(charset));
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 将编码的byteBuffer数据转换为字符串
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param data 数据
 | 
	
		
			
				|  |  | -     * @param charset 字符集,如果为空使用当前系统字符集
 | 
	
		
			
				|  |  | -     * @return 字符串
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static String str(ByteBuffer data, Charset charset)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        if (null == charset)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            charset = Charset.defaultCharset();
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        return charset.decode(data).toString();
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    // ----------------------------------------------------------------------- 全角半角转换
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 半角转全角
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param input String.
 | 
	
		
			
				|  |  | -     * @return 全角字符串.
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static String toSBC(String input)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        return toSBC(input, null);
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 半角转全角
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param input String
 | 
	
		
			
				|  |  | -     * @param notConvertSet 不替换的字符集合
 | 
	
		
			
				|  |  | -     * @return 全角字符串.
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static String toSBC(String input, Set<Character> notConvertSet)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        char c[] = input.toCharArray();
 | 
	
		
			
				|  |  | -        for (int i = 0; i < c.length; i++)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            if (null != notConvertSet && notConvertSet.contains(c[i]))
 | 
	
		
			
				|  |  | -            {
 | 
	
		
			
				|  |  | -                // 跳过不替换的字符
 | 
	
		
			
				|  |  | -                continue;
 | 
	
		
			
				|  |  | -            }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -            if (c[i] == ' ')
 | 
	
		
			
				|  |  | -            {
 | 
	
		
			
				|  |  | -                c[i] = '\u3000';
 | 
	
		
			
				|  |  | -            }
 | 
	
		
			
				|  |  | -            else if (c[i] < '\177')
 | 
	
		
			
				|  |  | -            {
 | 
	
		
			
				|  |  | -                c[i] = (char) (c[i] + 65248);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -            }
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        return new String(c);
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 全角转半角
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param input String.
 | 
	
		
			
				|  |  | -     * @return 半角字符串
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static String toDBC(String input)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        return toDBC(input, null);
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 替换全角为半角
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param text 文本
 | 
	
		
			
				|  |  | -     * @param notConvertSet 不替换的字符集合
 | 
	
		
			
				|  |  | -     * @return 替换后的字符
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static String toDBC(String text, Set<Character> notConvertSet)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        char c[] = text.toCharArray();
 | 
	
		
			
				|  |  | -        for (int i = 0; i < c.length; i++)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            if (null != notConvertSet && notConvertSet.contains(c[i]))
 | 
	
		
			
				|  |  | -            {
 | 
	
		
			
				|  |  | -                // 跳过不替换的字符
 | 
	
		
			
				|  |  | -                continue;
 | 
	
		
			
				|  |  | -            }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -            if (c[i] == '\u3000')
 | 
	
		
			
				|  |  | -            {
 | 
	
		
			
				|  |  | -                c[i] = ' ';
 | 
	
		
			
				|  |  | -            }
 | 
	
		
			
				|  |  | -            else if (c[i] > '\uFF00' && c[i] < '\uFF5F')
 | 
	
		
			
				|  |  | -            {
 | 
	
		
			
				|  |  | -                c[i] = (char) (c[i] - 65248);
 | 
	
		
			
				|  |  | -            }
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        String returnString = new String(c);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        return returnString;
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    /**
 | 
	
		
			
				|  |  | -     * 数字金额大写转换 先写个完整的然后将如零拾替换成零
 | 
	
		
			
				|  |  | -     * 
 | 
	
		
			
				|  |  | -     * @param n 数字
 | 
	
		
			
				|  |  | -     * @return 中文大写数字
 | 
	
		
			
				|  |  | -     */
 | 
	
		
			
				|  |  | -    public static String digitUppercase(double n)
 | 
	
		
			
				|  |  | -    {
 | 
	
		
			
				|  |  | -        String[] fraction = { "角", "分" };
 | 
	
		
			
				|  |  | -        String[] digit = { "零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖" };
 | 
	
		
			
				|  |  | -        String[][] unit = { { "元", "万", "亿" }, { "", "拾", "佰", "仟" } };
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        String head = n < 0 ? "负" : "";
 | 
	
		
			
				|  |  | -        n = Math.abs(n);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        String s = "";
 | 
	
		
			
				|  |  | -        for (int i = 0; i < fraction.length; i++)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            s += (digit[(int) (Math.floor(n * 10 * Math.pow(10, i)) % 10)] + fraction[i]).replaceAll("(零.)+", "");
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        if (s.length() < 1)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            s = "整";
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        int integerPart = (int) Math.floor(n);
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        for (int i = 0; i < unit[0].length && integerPart > 0; i++)
 | 
	
		
			
				|  |  | -        {
 | 
	
		
			
				|  |  | -            String p = "";
 | 
	
		
			
				|  |  | -            for (int j = 0; j < unit[1].length && n > 0; j++)
 | 
	
		
			
				|  |  | -            {
 | 
	
		
			
				|  |  | -                p = digit[integerPart % 10] + unit[1][j] + p;
 | 
	
		
			
				|  |  | -                integerPart = integerPart / 10;
 | 
	
		
			
				|  |  | -            }
 | 
	
		
			
				|  |  | -            s = p.replaceAll("(零.)*零$", "").replaceAll("^$", "零") + unit[0][i] + s;
 | 
	
		
			
				|  |  | -        }
 | 
	
		
			
				|  |  | -        return head + s.replaceAll("(零.)*零元", "元").replaceFirst("(零.)+", "").replaceAll("(零.)+", "零").replaceAll("^整$", "零元整");
 | 
	
		
			
				|  |  | -    }
 | 
	
		
			
				|  |  | -}
 |