【POI】Java设置Excel(.xlsx)单元格属性

2024-06-03 14:38

本文主要是介绍【POI】Java设置Excel(.xlsx)单元格属性,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

使用过的几种样式的设置方式:

XXXServiceImpl.java

public class XXXServiceImpl implements XXXService {@Overridepublic void test() {Map<String, Object> styleMap = new HashMap<String, Object>();styleMap.put("backgroundColor", new XSSFColor(new Color(0, 0, 0)));
//        styleMap.put("backgroundColor", IndexedColors.WHITE.getIndex());styleMap.put("fontColor", new XSSFColor(new Color(255, 255, 255)));styleMap.put("fontName", "MS Pゴシック");
//        styleMap.put("fontName", "Meiryo");styleMap.put("fontSize", (short) 10);styleMap.put("fontBold", true);styleMap.put("isHorizontalAlignCenter", true);// 细线styleMap.put("borderTopStyle", BorderStyle.THIN);
//        // 粗线
//        styleMap.put("borderTopStyle", BorderStyle.MEDIUM);
//        // 虚线
//        styleMap.put("borderTopStyle", BorderStyle.HAIR);styleMap.put("borderTopColor", new XSSFColor(new Color(0, 0, 0)));styleMap.put("dataFomrat", "#,##0");
//        styleMap.put("dataFomrat", "0%");
//        styleMap.put("dataFomrat", "0.00%");
//        styleMap.put("dataFomrat", "¥#,##0.0");
//        styleMap.put("dataFomrat", "¥#,##0");}
}

XSSFUtils.java

public class XSSFUtils {/*** セルの外観を設定する** @param workbook* @param cell* @param styleMap*              backgroundColor             XSSFColor*              fontColor                   XSSFColor*              fontName                    String*              fontSize                    Number*              fontBold                    boolean*              isHorizontalAlignCenter     boolean*              borderTopStyle              BorderStyle*              borderBottomStyle           BorderStyle*              borderLeftStyle             BorderStyle*              borderRightStyle            BorderStyle*              borderTopColor              XSSFColor*              borderBottomColor           XSSFColor*              borderLeftColor             XSSFColor*              borderRightColor            XSSFColor*              dataFomrat                  String*/public static void clearAndSetCellStyle(XSSFWorkbook workbook, XSSFCell cell, Map<String, Object> styleMap) {XSSFCellStyle cellStyle = workbook.createCellStyle();if (styleMap.get("backgroundColor") != null) {cellStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND);cellStyle.setFillForegroundColor((XSSFColor) styleMap.get("backgroundColor"));}XSSFFont font = workbook.createFont();if (styleMap.get("fontName") != null) {font.setFontName(styleMap.get("fontName").toString());}if (styleMap.get("fontColor") != null) {font.setColor((XSSFColor) styleMap.get("fontColor"));}if (styleMap.get("fontBold") != null) {font.setBold((boolean) styleMap.get("fontBold"));}if (styleMap.get("fontSize") != null) {font.setFontHeightInPoints(((Number) styleMap.get("fontSize")).shortValue());}cellStyle.setFont(font);if (styleMap.get("isHorizontalAlignCenter") != null) {boolean isHorizontalAlignCenter = (boolean) styleMap.get("isHorizontalAlignCenter");if (isHorizontalAlignCenter) {cellStyle.setAlignment(HorizontalAlignment.CENTER);}}cellStyle.setVerticalAlignment(VerticalAlignment.CENTER);if (styleMap.get("borderTopStyle") != null) {cellStyle.setBorderTop((BorderStyle) styleMap.get("borderTopStyle"));}if (styleMap.get("borderBottomStyle") != null) {cellStyle.setBorderBottom((BorderStyle) styleMap.get("borderBottomStyle"));}if (styleMap.get("borderLeftStyle") != null) {cellStyle.setBorderLeft((BorderStyle) styleMap.get("borderLeftStyle"));}if (styleMap.get("borderRightStyle") != null) {cellStyle.setBorderRight((BorderStyle) styleMap.get("borderRightStyle"));}if (styleMap.get("borderTopColor") != null) {cellStyle.setTopBorderColor((XSSFColor) styleMap.get("borderTopColor"));}if (styleMap.get("borderBottomColor") != null) {cellStyle.setBottomBorderColor((XSSFColor) styleMap.get("borderBottomColor"));}if (styleMap.get("borderLeftColor") != null) {cellStyle.setLeftBorderColor((XSSFColor) styleMap.get("borderLeftColor"));}if (styleMap.get("borderRightColor") != null) {cellStyle.setRightBorderColor((XSSFColor) styleMap.get("borderRightColor"));}if (styleMap.get("dataFomrat") != null) {cellStyle.setDataFormat(workbook.createDataFormat().getFormat(styleMap.get("dataFomrat").toString()));cell.setCellStyle(cellStyle);}cell.setCellStyle(cellStyle);}
}

 

这篇关于【POI】Java设置Excel(.xlsx)单元格属性的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1027278

相关文章

Java 8 Stream filter流式过滤器详解

《Java8Streamfilter流式过滤器详解》本文介绍了Java8的StreamAPI中的filter方法,展示了如何使用lambda表达式根据条件过滤流式数据,通过实际代码示例,展示了f... 目录引言 一.Java 8 Stream 的过滤器(filter)二.Java 8 的 filter、fi

Java中实现订单超时自动取消功能(最新推荐)

《Java中实现订单超时自动取消功能(最新推荐)》本文介绍了Java中实现订单超时自动取消功能的几种方法,包括定时任务、JDK延迟队列、Redis过期监听、Redisson分布式延迟队列、Rocket... 目录1、定时任务2、JDK延迟队列 DelayQueue(1)定义实现Delayed接口的实体类 (

springboot的调度服务与异步服务使用详解

《springboot的调度服务与异步服务使用详解》本文主要介绍了Java的ScheduledExecutorService接口和SpringBoot中如何使用调度线程池,包括核心参数、创建方式、自定... 目录1.调度服务1.1.JDK之ScheduledExecutorService1.2.spring

将java程序打包成可执行文件的实现方式

《将java程序打包成可执行文件的实现方式》本文介绍了将Java程序打包成可执行文件的三种方法:手动打包(将编译后的代码及JRE运行环境一起打包),使用第三方打包工具(如Launch4j)和JDK自带... 目录1.问题提出2.如何将Java程序打包成可执行文件2.1将编译后的代码及jre运行环境一起打包2

Java使用Tesseract-OCR实战教程

《Java使用Tesseract-OCR实战教程》本文介绍了如何在Java中使用Tesseract-OCR进行文本提取,包括Tesseract-OCR的安装、中文训练库的配置、依赖库的引入以及具体的代... 目录Java使用Tesseract-OCRTesseract-OCR安装配置中文训练库引入依赖代码实

Python自动化办公之合并多个Excel

《Python自动化办公之合并多个Excel》在日常的办公自动化工作中,尤其是处理大量数据时,合并多个Excel表格是一个常见且繁琐的任务,下面小编就来为大家介绍一下如何使用Python轻松实现合... 目录为什么选择 python 自动化目标使用 Python 合并多个 Excel 文件安装所需库示例代码

Java中对象的创建和销毁过程详析

《Java中对象的创建和销毁过程详析》:本文主要介绍Java中对象的创建和销毁过程,对象的创建过程包括类加载检查、内存分配、初始化零值内存、设置对象头和执行init方法,对象的销毁过程由垃圾回收机... 目录前言对象的创建过程1. 类加载检查2China编程. 分配内存3. 初始化零值4. 设置对象头5. 执行

SpringBoot整合easy-es的详细过程

《SpringBoot整合easy-es的详细过程》本文介绍了EasyES,一个基于Elasticsearch的ORM框架,旨在简化开发流程并提高效率,EasyES支持SpringBoot框架,并提供... 目录一、easy-es简介二、实现基于Spring Boot框架的应用程序代码1.添加相关依赖2.添

通俗易懂的Java常见限流算法具体实现

《通俗易懂的Java常见限流算法具体实现》:本文主要介绍Java常见限流算法具体实现的相关资料,包括漏桶算法、令牌桶算法、Nginx限流和Redis+Lua限流的实现原理和具体步骤,并比较了它们的... 目录一、漏桶算法1.漏桶算法的思想和原理2.具体实现二、令牌桶算法1.令牌桶算法流程:2.具体实现2.1

SpringBoot中整合RabbitMQ(测试+部署上线最新完整)的过程

《SpringBoot中整合RabbitMQ(测试+部署上线最新完整)的过程》本文详细介绍了如何在虚拟机和宝塔面板中安装RabbitMQ,并使用Java代码实现消息的发送和接收,通过异步通讯,可以优化... 目录一、RabbitMQ安装二、启动RabbitMQ三、javascript编写Java代码1、引入