| | |
| | |
|
| | | import java.math.BigDecimal;
|
| | | import java.math.BigInteger;
|
| | | import java.math.RoundingMode;
|
| | | import java.nio.ByteBuffer;
|
| | | import java.nio.charset.Charset;
|
| | | import java.text.NumberFormat;
|
| | | import java.util.Set;
|
| | | import com.ruoyi.common.utils.StringUtils;
|
| | | import org.apache.commons.lang3.ArrayUtils;
|
| | |
|
| | | /**
|
| | | * 类型转换器
|
| | | * |
| | | *
|
| | | * @author ruoyi
|
| | | */
|
| | | public class Convert
|
| | |
| | | * 转换为字符串<br>
|
| | | * 如果给定的值为null,或者转换失败,返回默认值<br>
|
| | | * 转换失败不会报错
|
| | | * |
| | | *
|
| | | * @param value 被转换的值
|
| | | * @param defaultValue 转换错误时的默认值
|
| | | * @return 结果
|
| | |
| | | * 转换为字符串<br>
|
| | | * 如果给定的值为<code>null</code>,或者转换失败,返回默认值<code>null</code><br>
|
| | | * 转换失败不会报错
|
| | | * |
| | | *
|
| | | * @param value 被转换的值
|
| | | * @return 结果
|
| | | */
|
| | |
| | | * 转换为字符<br>
|
| | | * 如果给定的值为null,或者转换失败,返回默认值<br>
|
| | | * 转换失败不会报错
|
| | | * |
| | | *
|
| | | * @param value 被转换的值
|
| | | * @param defaultValue 转换错误时的默认值
|
| | | * @return 结果
|
| | |
| | | * 转换为字符<br>
|
| | | * 如果给定的值为<code>null</code>,或者转换失败,返回默认值<code>null</code><br>
|
| | | * 转换失败不会报错
|
| | | * |
| | | *
|
| | | * @param value 被转换的值
|
| | | * @return 结果
|
| | | */
|
| | |
| | | * 转换为byte<br>
|
| | | * 如果给定的值为<code>null</code>,或者转换失败,返回默认值<br>
|
| | | * 转换失败不会报错
|
| | | * |
| | | *
|
| | | * @param value 被转换的值
|
| | | * @param defaultValue 转换错误时的默认值
|
| | | * @return 结果
|
| | |
| | | * 转换为byte<br>
|
| | | * 如果给定的值为<code>null</code>,或者转换失败,返回默认值<code>null</code><br>
|
| | | * 转换失败不会报错
|
| | | * |
| | | *
|
| | | * @param value 被转换的值
|
| | | * @return 结果
|
| | | */
|
| | |
| | | * 转换为Short<br>
|
| | | * 如果给定的值为<code>null</code>,或者转换失败,返回默认值<br>
|
| | | * 转换失败不会报错
|
| | | * |
| | | *
|
| | | * @param value 被转换的值
|
| | | * @param defaultValue 转换错误时的默认值
|
| | | * @return 结果
|
| | |
| | | * 转换为Short<br>
|
| | | * 如果给定的值为<code>null</code>,或者转换失败,返回默认值<code>null</code><br>
|
| | | * 转换失败不会报错
|
| | | * |
| | | *
|
| | | * @param value 被转换的值
|
| | | * @return 结果
|
| | | */
|
| | |
| | | * 转换为Number<br>
|
| | | * 如果给定的值为空,或者转换失败,返回默认值<br>
|
| | | * 转换失败不会报错
|
| | | * |
| | | *
|
| | | * @param value 被转换的值
|
| | | * @param defaultValue 转换错误时的默认值
|
| | | * @return 结果
|
| | |
| | | * 转换为Number<br>
|
| | | * 如果给定的值为空,或者转换失败,返回默认值<code>null</code><br>
|
| | | * 转换失败不会报错
|
| | | * |
| | | *
|
| | | * @param value 被转换的值
|
| | | * @return 结果
|
| | | */
|
| | |
| | | * 转换为int<br>
|
| | | * 如果给定的值为空,或者转换失败,返回默认值<br>
|
| | | * 转换失败不会报错
|
| | | * |
| | | *
|
| | | * @param value 被转换的值
|
| | | * @param defaultValue 转换错误时的默认值
|
| | | * @return 结果
|
| | |
| | | * 转换为int<br>
|
| | | * 如果给定的值为<code>null</code>,或者转换失败,返回默认值<code>null</code><br>
|
| | | * 转换失败不会报错
|
| | | * |
| | | *
|
| | | * @param value 被转换的值
|
| | | * @return 结果
|
| | | */
|
| | |
| | |
|
| | | /**
|
| | | * 转换为Integer数组<br>
|
| | | * |
| | | *
|
| | | * @param str 被转换的值
|
| | | * @return 结果
|
| | | */
|
| | |
| | |
|
| | | /**
|
| | | * 转换为Long数组<br>
|
| | | * |
| | | *
|
| | | * @param str 被转换的值
|
| | | * @return 结果
|
| | | */
|
| | |
| | |
|
| | | /**
|
| | | * 转换为Integer数组<br>
|
| | | * |
| | | *
|
| | | * @param split 分隔符
|
| | | * @param split 被转换的值
|
| | | * @return 结果
|
| | |
| | |
|
| | | /**
|
| | | * 转换为Long数组<br>
|
| | | * |
| | | *
|
| | | * @param split 分隔符
|
| | | * @param str 被转换的值
|
| | | * @return 结果
|
| | |
| | |
|
| | | /**
|
| | | * 转换为String数组<br>
|
| | | * |
| | | *
|
| | | * @param str 被转换的值
|
| | | * @return 结果
|
| | | */
|
| | | public static String[] toStrArray(String str)
|
| | | {
|
| | | if (StringUtils.isEmpty(str))
|
| | | {
|
| | | return new String[] {};
|
| | | }
|
| | | return toStrArray(",", str);
|
| | | }
|
| | |
|
| | | /**
|
| | | * 转换为String数组<br>
|
| | | * |
| | | *
|
| | | * @param split 分隔符
|
| | | * @param split 被转换的值
|
| | | * @return 结果
|
| | |
| | | * 转换为long<br>
|
| | | * 如果给定的值为空,或者转换失败,返回默认值<br>
|
| | | * 转换失败不会报错
|
| | | * |
| | | *
|
| | | * @param value 被转换的值
|
| | | * @param defaultValue 转换错误时的默认值
|
| | | * @return 结果
|
| | |
| | | * 转换为long<br>
|
| | | * 如果给定的值为<code>null</code>,或者转换失败,返回默认值<code>null</code><br>
|
| | | * 转换失败不会报错
|
| | | * |
| | | *
|
| | | * @param value 被转换的值
|
| | | * @return 结果
|
| | | */
|
| | |
| | | * 转换为double<br>
|
| | | * 如果给定的值为空,或者转换失败,返回默认值<br>
|
| | | * 转换失败不会报错
|
| | | * |
| | | *
|
| | | * @param value 被转换的值
|
| | | * @param defaultValue 转换错误时的默认值
|
| | | * @return 结果
|
| | |
| | | * 转换为double<br>
|
| | | * 如果给定的值为空,或者转换失败,返回默认值<code>null</code><br>
|
| | | * 转换失败不会报错
|
| | | * |
| | | *
|
| | | * @param value 被转换的值
|
| | | * @return 结果
|
| | | */
|
| | |
| | | * 转换为Float<br>
|
| | | * 如果给定的值为空,或者转换失败,返回默认值<br>
|
| | | * 转换失败不会报错
|
| | | * |
| | | *
|
| | | * @param value 被转换的值
|
| | | * @param defaultValue 转换错误时的默认值
|
| | | * @return 结果
|
| | |
| | | * 转换为Float<br>
|
| | | * 如果给定的值为空,或者转换失败,返回默认值<code>null</code><br>
|
| | | * 转换失败不会报错
|
| | | * |
| | | *
|
| | | * @param value 被转换的值
|
| | | * @return 结果
|
| | | */
|
| | |
| | |
|
| | | /**
|
| | | * 转换为boolean<br>
|
| | | * String支持的值为:true、false、yes、ok、no,1,0 如果给定的值为空,或者转换失败,返回默认值<br>
|
| | | * String支持的值为:true、false、yes、ok、no、1、0、是、否, 如果给定的值为空,或者转换失败,返回默认值<br>
|
| | | * 转换失败不会报错
|
| | | * |
| | | *
|
| | | * @param value 被转换的值
|
| | | * @param defaultValue 转换错误时的默认值
|
| | | * @return 结果
|
| | |
| | | switch (valueStr)
|
| | | {
|
| | | case "true":
|
| | | case "yes":
|
| | | case "ok":
|
| | | case "1":
|
| | | case "是":
|
| | | return true;
|
| | | case "false":
|
| | | return false;
|
| | | case "yes":
|
| | | return true;
|
| | | case "ok":
|
| | | return true;
|
| | | case "no":
|
| | | return false;
|
| | | case "1":
|
| | | return true;
|
| | | case "0":
|
| | | case "否":
|
| | | return false;
|
| | | default:
|
| | | return defaultValue;
|
| | |
| | | * 转换为boolean<br>
|
| | | * 如果给定的值为空,或者转换失败,返回默认值<code>null</code><br>
|
| | | * 转换失败不会报错
|
| | | * |
| | | *
|
| | | * @param value 被转换的值
|
| | | * @return 结果
|
| | | */
|
| | |
| | | /**
|
| | | * 转换为Enum对象<br>
|
| | | * 如果给定的值为空,或者转换失败,返回默认值<br>
|
| | | * |
| | | *
|
| | | * @param clazz Enum的Class
|
| | | * @param value 值
|
| | | * @param defaultValue 默认值
|
| | |
| | | /**
|
| | | * 转换为Enum对象<br>
|
| | | * 如果给定的值为空,或者转换失败,返回默认值<code>null</code><br>
|
| | | * |
| | | *
|
| | | * @param clazz Enum的Class
|
| | | * @param value 值
|
| | | * @return Enum
|
| | |
| | | * 转换为BigInteger<br>
|
| | | * 如果给定的值为空,或者转换失败,返回默认值<br>
|
| | | * 转换失败不会报错
|
| | | * |
| | | *
|
| | | * @param value 被转换的值
|
| | | * @param defaultValue 转换错误时的默认值
|
| | | * @return 结果
|
| | |
| | | * 转换为BigInteger<br>
|
| | | * 如果给定的值为空,或者转换失败,返回默认值<code>null</code><br>
|
| | | * 转换失败不会报错
|
| | | * |
| | | *
|
| | | * @param value 被转换的值
|
| | | * @return 结果
|
| | | */
|
| | |
| | | * 转换为BigDecimal<br>
|
| | | * 如果给定的值为空,或者转换失败,返回默认值<br>
|
| | | * 转换失败不会报错
|
| | | * |
| | | *
|
| | | * @param value 被转换的值
|
| | | * @param defaultValue 转换错误时的默认值
|
| | | * @return 结果
|
| | |
| | | }
|
| | | if (value instanceof Double)
|
| | | {
|
| | | return new BigDecimal((Double) value);
|
| | | return BigDecimal.valueOf((Double) value);
|
| | | }
|
| | | if (value instanceof Integer)
|
| | | {
|
| | |
| | | * 转换为BigDecimal<br>
|
| | | * 如果给定的值为空,或者转换失败,返回默认值<br>
|
| | | * 转换失败不会报错
|
| | | * |
| | | *
|
| | | * @param value 被转换的值
|
| | | * @return 结果
|
| | | */
|
| | |
| | | /**
|
| | | * 将对象转为字符串<br>
|
| | | * 1、Byte数组和ByteBuffer会被转换为对应字符串的数组 2、对象数组会调用Arrays.toString方法
|
| | | * |
| | | *
|
| | | * @param obj 对象
|
| | | * @return 字符串
|
| | | */
|
| | |
| | | /**
|
| | | * 将对象转为字符串<br>
|
| | | * 1、Byte数组和ByteBuffer会被转换为对应字符串的数组 2、对象数组会调用Arrays.toString方法
|
| | | * |
| | | *
|
| | | * @param obj 对象
|
| | | * @param charsetName 字符集
|
| | | * @return 字符串
|
| | |
| | | /**
|
| | | * 将对象转为字符串<br>
|
| | | * 1、Byte数组和ByteBuffer会被转换为对应字符串的数组 2、对象数组会调用Arrays.toString方法
|
| | | * |
| | | *
|
| | | * @param obj 对象
|
| | | * @param charset 字符集
|
| | | * @return 字符串
|
| | |
| | | {
|
| | | return (String) obj;
|
| | | }
|
| | | else if (obj instanceof byte[] || obj instanceof Byte[])
|
| | | else if (obj instanceof byte[])
|
| | | {
|
| | | return str((Byte[]) obj, charset);
|
| | | 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)
|
| | | {
|
| | |
| | |
|
| | | /**
|
| | | * 将byte数组转为字符串
|
| | | * |
| | | *
|
| | | * @param bytes byte数组
|
| | | * @param charset 字符集
|
| | | * @return 字符串
|
| | |
| | |
|
| | | /**
|
| | | * 解码字节码
|
| | | * |
| | | *
|
| | | * @param data 字符串
|
| | | * @param charset 字符集,如果此字段为空,则解码的结果取决于平台
|
| | | * @return 解码后的字符串
|
| | |
| | |
|
| | | /**
|
| | | * 将编码的byteBuffer数据转换为字符串
|
| | | * |
| | | *
|
| | | * @param data 数据
|
| | | * @param charset 字符集,如果为空使用当前系统字符集
|
| | | * @return 字符串
|
| | |
| | |
|
| | | /**
|
| | | * 将编码的byteBuffer数据转换为字符串
|
| | | * |
| | | *
|
| | | * @param data 数据
|
| | | * @param charset 字符集,如果为空使用当前系统字符集
|
| | | * @return 字符串
|
| | |
| | | // ----------------------------------------------------------------------- 全角半角转换
|
| | | /**
|
| | | * 半角转全角
|
| | | * |
| | | *
|
| | | * @param input String.
|
| | | * @return 全角字符串.
|
| | | */
|
| | |
| | |
|
| | | /**
|
| | | * 半角转全角
|
| | | * |
| | | *
|
| | | * @param input String
|
| | | * @param notConvertSet 不替换的字符集合
|
| | | * @return 全角字符串.
|
| | | */
|
| | | public static String toSBC(String input, Set<Character> notConvertSet)
|
| | | {
|
| | | char c[] = input.toCharArray();
|
| | | char[] c = input.toCharArray();
|
| | | for (int i = 0; i < c.length; i++)
|
| | | {
|
| | | if (null != notConvertSet && notConvertSet.contains(c[i]))
|
| | |
| | |
|
| | | /**
|
| | | * 全角转半角
|
| | | * |
| | | *
|
| | | * @param input String.
|
| | | * @return 半角字符串
|
| | | */
|
| | |
| | |
|
| | | /**
|
| | | * 替换全角为半角
|
| | | * |
| | | *
|
| | | * @param text 文本
|
| | | * @param notConvertSet 不替换的字符集合
|
| | | * @return 替换后的字符
|
| | | */
|
| | | public static String toDBC(String text, Set<Character> notConvertSet)
|
| | | {
|
| | | char c[] = text.toCharArray();
|
| | | char[] c = text.toCharArray();
|
| | | for (int i = 0; i < c.length; i++)
|
| | | {
|
| | | if (null != notConvertSet && notConvertSet.contains(c[i]))
|
| | |
| | |
|
| | | /**
|
| | | * 数字金额大写转换 先写个完整的然后将如零拾替换成零
|
| | | * |
| | | *
|
| | | * @param n 数字
|
| | | * @return 中文大写数字
|
| | | */
|
| | |
| | | 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("(零.)+", "");
|
| | | // 优化double计算精度丢失问题
|
| | | BigDecimal nNum = new BigDecimal(n);
|
| | | BigDecimal decimal = new BigDecimal(10);
|
| | | BigDecimal scale = nNum.multiply(decimal).setScale(2, RoundingMode.HALF_EVEN);
|
| | | double d = scale.doubleValue();
|
| | | s += (digit[(int) (Math.floor(d * Math.pow(10, i)) % 10)] + fraction[i]).replaceAll("(零.)+", "");
|
| | | }
|
| | | if (s.length() < 1)
|
| | | {
|