Bläddra i källkod

excel模板填充

LIVE_YE 7 månader sedan
förälder
incheckning
5ec763e72f

+ 94 - 0
ruoyi-common/src/main/java/com/ruoyi/common/utils/PriceConverter/PriceConverter.java

@@ -0,0 +1,94 @@
+package com.ruoyi.common.utils.PriceConverter;
+
+import java.math.BigDecimal;
+
+public class PriceConverter {
+
+    private static final String[] CHINESE_NUMBERS = {"零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖"};
+    private static final String[] UNITS = {"", "拾", "佰", "仟"};
+    private static final String[] BIG_UNITS = {"", "万", "亿", "兆", "京", "垓", "秭", "穰", "沟", "涧", "正", "载", "极"}; // 根据需要可以增加更多大单位
+
+    public static String convertToChinese(BigDecimal price) {
+        if (price == null || price.compareTo(BigDecimal.ZERO) < 0) {
+            throw new IllegalArgumentException("价格不能为空或小于0");
+        }
+
+        // 转换为字符串并截取小数点前后部分
+        String priceStr = price.setScale(2, BigDecimal.ROUND_HALF_UP).toPlainString();
+        String integerPart = priceStr.split("\\.")[0]; // 整数部分
+        String decimalPart = priceStr.split("\\.")[1]; // 小数部分(角、分)
+
+        // 处理整数部分
+        String integerChinese = convertToChinesePart(integerPart, UNITS, BIG_UNITS);
+
+        // 处理小数部分
+        String decimalChinese = "";
+        if (!"00".equals(decimalPart)) {
+            decimalChinese = convertToDecimalChinese(decimalPart);
+        }
+
+        // 合并结果
+        return integerChinese + "元" + decimalChinese;
+    }
+
+    private static String convertToChinesePart(String numberStr, String[] units, String[] bigUnits) {
+        if ("0".equals(numberStr)) {
+            return CHINESE_NUMBERS[0];
+        }
+
+        StringBuilder sb = new StringBuilder();
+        int unitIndex = 0;
+//        int zeroCount = 0;
+
+        for (int i = numberStr.length() - 1; i >= 0; i--) {
+            int digit = numberStr.charAt(i) - '0';
+            String chineseDigit = CHINESE_NUMBERS[digit];
+
+            if (digit == 0) {
+//                zeroCount++;
+                // 连续零的处理:只在非零数字后面、单位变化处或字符串开始处添加一个零
+                if (sb.length() > 0 && (sb.charAt(sb.length() - 1) != CHINESE_NUMBERS[0].charAt(0) || unitIndex == 0 || i == 0)) {
+                    sb.insert(0, chineseDigit);
+                }
+            } else {
+                // 添加非零数字和对应单位
+                sb.insert(0, chineseDigit + units[unitIndex]);
+//                zeroCount = 0; // 重置连续零的计数
+            }
+
+            // 切换到下一个单位
+            if (++unitIndex == units.length) {
+                unitIndex = 0; // 循环使用单位数组
+                if (sb.length() > 0 && i > 0) {
+                    sb.insert(0, bigUnits[(numberStr.length()-i) / units.length]);
+                }
+            }
+        }
+
+        // 去除末尾可能多余的零
+        while (sb.length() > 0 && sb.charAt(0) == CHINESE_NUMBERS[0].charAt(0)) {
+            sb.deleteCharAt(0);
+        }
+
+        return sb.toString();
+    }
+
+    private static String convertToDecimalChinese(String decimalPart) {
+        StringBuilder sb = new StringBuilder();
+        if (decimalPart.charAt(0) != '0') {
+            sb.append(CHINESE_NUMBERS[decimalPart.charAt(0) - '0']).append("角");
+        }
+        if (decimalPart.length() > 1 && decimalPart.charAt(1) != '0') {
+            sb.append(CHINESE_NUMBERS[decimalPart.charAt(1) - '0']).append("分");
+        }
+        return sb.toString();
+    }
+
+    public static void main(String[] args) {
+        System.out.println(convertToChinese(new BigDecimal("4545444444111141233123522212345.67"))); // 肆佰伍拾肆穰伍仟肆佰肆拾肆秭肆仟肆佰肆拾壹垓壹仟壹佰壹拾肆京壹仟贰佰叁拾叁兆壹仟贰佰叁拾伍亿贰仟贰佰贰拾壹万贰仟叁佰肆拾伍元陆角柒分
+        System.out.println(convertToChinese(new BigDecimal("100.00"))); // 壹佰元
+        System.out.println(convertToChinese(new BigDecimal("0.01"))); // 零元壹分
+        System.out.println(convertToChinese(new BigDecimal("0.00"))); // 零元
+    }
+}
+

+ 3 - 4
ruoyi-framework/src/main/java/com/ruoyi/framework/web/service/LoanApplicationServiceImpl.java

@@ -12,6 +12,7 @@ import com.ruoyi.common.core.domain.entity.SysUser;
 import com.ruoyi.common.core.redis.RedisCache;
 import com.ruoyi.common.enums.FjType;
 import com.ruoyi.common.utils.*;
+import com.ruoyi.common.utils.PriceConverter.PriceConverter;
 import com.ruoyi.common.utils.jPush.JPushToolUtil;
 import com.ruoyi.common.utils.poi.ExcelFillUtils;
 import com.ruoyi.common.utils.poi.WordUtil;
@@ -41,6 +42,7 @@ import org.springframework.transaction.annotation.Transactional;
 
 import javax.annotation.Resource;
 import java.io.*;
+import java.math.BigDecimal;
 import java.util.*;
 import java.util.concurrent.TimeUnit;
 import java.util.stream.Collectors;
@@ -1842,10 +1844,7 @@ public class LoanApplicationServiceImpl implements ILoanApplicationService {
         String backName = dictDataMapper.selectDictLabel("shendai_bank", loanApplication.getApplicationBank());
         params.put("backName", backName);
         //将贷款金额转成中文
-        String chineseNum = loanApplication.getLoanApplicationNumber();
-        if (StringUtils.isNumeric(loanApplication.getLoanApplicationNumber())) {
-            chineseNum = StringUtils.convert(Integer.parseInt(loanApplication.getLoanApplicationNumber()));
-        }
+        String chineseNum = PriceConverter.convertToChinese(new BigDecimal(Double.toString(loanApplication.getApplicationAmount())));
         params.put("chineseNum", chineseNum);
 
         String templatePath = RuoYiConfig.getProfile();

+ 2 - 2
ruoyi-system/src/main/resources/mapper/system/SysUserConferenceMapper.xml

@@ -73,10 +73,10 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
             <if test="guaranteePeriod != null  ">guarantee_period ,</if>
             <if test="argument != null  ">argument,</if>
             <if test="createBy != null">create_by,</if>
-            <if test="createTime != null">create_time,</if>
             <if test="updateBy != null">update_by,</if>
             <if test="updateTime != null">update_time,</if>
             <if test="remark != null">remark,</if>
+            create_time
          </trim>
         <trim prefix="values (" suffix=")" suffixOverrides=",">
             <if test="userId != null">#{userId},</if>
@@ -93,10 +93,10 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
             <if test="guaranteePeriod != null  ">#{guaranteePeriod},</if>
             <if test="argument != null  ">#{argument},</if>
             <if test="createBy != null">#{createBy},</if>
-            <if test="createTime != null">#{createTime},</if>
             <if test="updateBy != null">#{updateBy},</if>
             <if test="updateTime != null">#{updateTime},</if>
             <if test="remark != null">#{remark},</if>
+            sysdate()
          </trim>
     </insert>
     <insert id="batchSysUserConference">