|  | @@ -0,0 +1,989 @@
 | 
												
													
														
															|  | 
 |  | +package com.jeeplus.sys.utils;
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  | 
 |  | +import org.apache.commons.lang3.ArrayUtils;
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  | 
 |  | +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;
 | 
												
													
														
															|  | 
 |  | +
 | 
												
													
														
															|  | 
 |  | +/**
 | 
												
													
														
															|  | 
 |  | + * 类型转换器
 | 
												
													
														
															|  | 
 |  | + *
 | 
												
													
														
															|  | 
 |  | + * @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":
 | 
												
													
														
															|  | 
 |  | +            case "yes":
 | 
												
													
														
															|  | 
 |  | +            case "ok":
 | 
												
													
														
															|  | 
 |  | +            case "1":
 | 
												
													
														
															|  | 
 |  | +                return true;
 | 
												
													
														
															|  | 
 |  | +            case "false":
 | 
												
													
														
															|  | 
 |  | +            case "no":
 | 
												
													
														
															|  | 
 |  | +            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 对象
 | 
												
													
														
															|  | 
 |  | +     * @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[])
 | 
												
													
														
															|  | 
 |  | +        {
 | 
												
													
														
															|  | 
 |  | +            return str((byte[]) obj, charset);
 | 
												
													
														
															|  | 
 |  | +        }
 | 
												
													
														
															|  | 
 |  | +        else if (obj instanceof Byte[])
 | 
												
													
														
															|  | 
 |  | +        {
 | 
												
													
														
															|  | 
 |  | +            byte[] bytes = ArrayUtils.toPrimitive((Byte[]) obj);
 | 
												
													
														
															|  | 
 |  | +            return str(bytes, 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("^整$", "零元整");
 | 
												
													
														
															|  | 
 |  | +    }
 | 
												
													
														
															|  | 
 |  | +}
 |