JAVA 使用apache poi实现EXCEL文件的输出;apache poi实现标题行的第一个字符为红色;EXCEL设置某几个字符为别的颜色

设置输出文件的列宽,防止文件过于丑陋

复制代码
Sheet sheet = workbook.createSheet(FileConstants.ERROR_FILE_SHEET_NAME);
sheet.setColumnWidth(0, 40 * 256);
sheet.setColumnWidth(1, 20 * 256);
sheet.setColumnWidth(2, 20 * 256);
sheet.setColumnWidth(3, 20 * 256);

实现标题行的第一个字符为红色,效果如图

//这边的0,1 就是设置第一个字符

Font font = workbook.createFont(); font.setColor(IndexedColors.RED.getIndex());

RichTextString store = workbook.getCreationHelper().createRichTextString(FileConstants.UPDATE_TEMPLATE_NAMES.get(Constants.ZERO)); store.applyFont(0, 1, font);

titleRow.createCell(Constants.ONE_INT).setCellValue(store);

判断如果是第一列的话 设置字体为红色

复制代码
if (Constants.ZERO.equals(columnIndex)) {

    cellStyle.setFont(font);
    cell.setCellStyle(cellStyle);
}

将文件上传oss保存,可以忽略

复制代码
try (InputStream inputStream = new ByteArrayInputStream(out.toByteArray())) {
    aliyunOssUtil.uploadFile(ossFilePath, inputStream);
}

完整代码如下:

java 复制代码
    private void uploadErrorFile(List<BatchUpdateStatusFileDTO> list, String fileBatchId) {

        try (ByteArrayOutputStream out = new ByteArrayOutputStream();
             Workbook workbook = new XSSFWorkbook()) {
            Sheet sheet = workbook.createSheet(FileConstants.ERROR_FILE_SHEET_NAME);
            sheet.setColumnWidth(0, 40 * 256);
            sheet.setColumnWidth(1, 20 * 256);
            sheet.setColumnWidth(2, 20 * 256);
            sheet.setColumnWidth(3, 20 * 256);
            // 创建标题行
            Row titleRow = sheet.createRow(0);
            titleRow.createCell(Constants.ZERO).setCellValue(StringPool.EMPTY);
            Font font = workbook.createFont();
            font.setColor(IndexedColors.RED.getIndex());
            RichTextString store = workbook.getCreationHelper().createRichTextString(FileConstants.UPDATE_TEMPLATE_NAMES.get(Constants.ZERO));
            store.applyFont(0, 1, font);
            titleRow.createCell(Constants.ONE_INT).setCellValue(store);
            RichTextString number = workbook.getCreationHelper().createRichTextString(FileConstants.UPDATE_TEMPLATE_NAMES.get(Constants.ONE_INT));
            number.applyFont(0, 1, font);
            titleRow.createCell(Constants.TWO_INT).setCellValue(number);
            RichTextString status = workbook.getCreationHelper().createRichTextString(FileConstants.UPDATE_TEMPLATE_NAMES.get(Constants.TWO_INT));
            status.applyFont(0, 1, font);
            titleRow.createCell(Constants.THREE_INT).setCellValue(status);
            // 创建数据行
            for (int i = 0; i < theResList.size(); i++) {
                BatchUpdateStatusFileDTO data = theResList.get(i);
                Row row = sheet.createRow(i + 1);
                createCell(row, Constants.ZERO, data.getCheckResult(), workbook, font);
                createCell(row, Constants.ONE_INT, data.getSalesStore(), workbook, font);
                createCell(row, Constants.TWO_INT, data.getSalesOrder(), workbook, font);
                createCell(row, Constants.THREE_INT, data.getSalesStatus(), workbook, font);
            }
            String ossFilePath = String.format(FileConstants.BATCH_UPDATE_ERROR_FILE_PATH, fileBatchId);
            // 将Excel输出为InputStream
            workbook.write(out);
            try (InputStream inputStream = new ByteArrayInputStream(out.toByteArray())) {
                aliyunOssUtil.uploadFile(ossFilePath, inputStream);
            }
        } catch (Exception e) {
            log.error("---Modify the order status in batches, failed to upload an error file---", e);
        }
    }


    private void createCell(Row row, int columnIndex, Object value, Workbook workbook, Font font) {
        Cell cell = row.createCell(columnIndex);
        if (value instanceof String) {
            cell.setCellValue((String) value);
        } else if (value instanceof Integer) {
            cell.setCellValue((Integer) value);
        } else {
            cell.setCellValue(value.toString());
        }
        CellStyle cellStyle = workbook.createCellStyle();
        cellStyle.setWrapText(Boolean.TRUE);
        cellStyle.setVerticalAlignment(VerticalAlignment.CENTER);
        cell.setCellStyle(cellStyle);
        if (Constants.ZERO.equals(columnIndex)) {

            cellStyle.setFont(font);
            cell.setCellStyle(cellStyle);
        }
    }
相关推荐
喻米粒06221 小时前
RabbitMQ消息相关
java·jvm·spring boot·spring·spring cloud·sentinel·java-rabbitmq
Aphelios3803 小时前
Java全栈面试宝典:线程机制与Spring IOC容器深度解析
java·开发语言·jvm·学习·rbac
qq_529835354 小时前
装饰器模式:如何用Java打扮一个对象?
java·开发语言·装饰器模式
日暮南城故里4 小时前
Java学习------源码解析之StringBuilder
java·开发语言·学习·源码
一个public的class6 小时前
什么是 Java 泛型
java·开发语言·后端
士别三日&&当刮目相看6 小时前
JAVA学习*Object类
java·开发语言·学习
快来卷java7 小时前
MySQL篇(一):慢查询定位及索引、B树相关知识详解
java·数据结构·b树·mysql·adb
hello_simon7 小时前
在线Excel 转换为 txt ,超方便超易用软件,在线转换,大力提升工作效率
excel
凸头7 小时前
I/O多路复用 + Reactor和Proactor + 一致性哈希
java·哈希算法
慵懒学者8 小时前
15 网络编程:三要素(IP地址、端口、协议)、UDP通信实现和TCP通信实现 (黑马Java视频笔记)
java·网络·笔记·tcp/ip·udp