基于poi生成excel模板并生成下拉选择框

news/2024/11/29 8:01:51/

直接上代码(有注释)

public void downloadImportTemplate(HttpServletResponse response) {try {ServletOutputStream outputStream = response.getOutputStream();//创建工作表XSSFWorkbook workbook = new XSSFWorkbook();//标题行的标题List<String> requireRowNameList = Collections.singletonList("订单编号");List<String> optionalRowNameList = Arrays.asList("用户编号");String fileName = "导入模板" + DateUtils.formatDateTime();XSSFSheet sheet = workbook.createSheet("导入模板");XSSFRow row = null;XSSFCell cell = null;//----------------标题样式---------------------XSSFCellStyle titleStyle = workbook.createCellStyle();//标题样式titleStyle.setAlignment(HorizontalAlignment.CENTER);titleStyle.setVerticalAlignment(VerticalAlignment.CENTER);Font titleFont = workbook.createFont();titleFont.setFontHeightInPoints((short) 22);titleFont.setFontName("微软雅黑");titleFont.setBold(true);titleStyle.setFont(titleFont);//----------------列样式2 必填字段显红色---------------------XSSFCellStyle cellStyle2 = workbook.createCellStyle();cellStyle2.setAlignment(HorizontalAlignment.CENTER);cellStyle2.setVerticalAlignment(VerticalAlignment.CENTER);Font cellFont2 = workbook.createFont();cellFont2.setFontName("微软雅黑");cellFont2.setBold(true);cellFont2.setColor((short) 0xa); // 红色cellStyle2.setFont(cellFont2);//----------------列样式3 非必填字段显黑色---------------------XSSFCellStyle cellStyle3 = workbook.createCellStyle();cellStyle3.setAlignment(HorizontalAlignment.CENTER);cellStyle3.setVerticalAlignment(VerticalAlignment.CENTER);Font cellFont3 = workbook.createFont();cellFont3.setFontName("微软雅黑");cellFont3.setBold(true);cellStyle3.setFont(cellFont3 );//------------------- 创建第一行(字段名) --------------------row = sheet.createRow(0);sheet.setDefaultColumnWidth(20);sheet.autoSizeColumn(1);sheet.autoSizeColumn(1, true);int i = 0;for (; i < requireRowNameList.size(); i++) {cell = row.createCell(i);//必填列红色显示cell.setCellStyle(cellStyle2);cell.setCellValue(requireRowNameList.get(i));}int j = 0;for (; j < optionalRowNameList.size(); i++, j++) {cell = row.createCell(i);//非必填列黑色显示cell.setCellStyle(cellStyle3);cell.setCellValue(optionalRowNameList.get(j));}cell = row.createCell(i);//非必填列黑色显示cell.setCellStyle(cellStyle3);cell.setCellValue("是否通知客户");//--------------------设置下拉选择框的代码-----------------------------//选择框可选值String[] datas = new String[]{"是", "否"};//设置需要生成下拉列表的表格范围,1代表从第二行开始,30000代表一直到第三万零一行,第i+1列开始,到第i+1列;CellRangeAddressList cellRangeAddressList = new CellRangeAddressList(1, 30000, i, i);//生成下拉框内容DataValidationHelper dvHelper = sheet.getDataValidationHelper();DataValidationConstraint dvConstraint = dvHelper.createExplicitListConstraint(datas);DataValidation validation = dvHelper.createValidation(dvConstraint, cellRangeAddressList);//设置错误信息提示validation.setShowErrorBox(true);//对sheet页生效sheet.addValidationData(validation);//------------------------------------------------response.setContentType("application/binary;charset=UTF-8");response.setHeader("Content-Disposition", "attachment;fileName=" + URLEncoder.encode(fileName + ".xlsx", "UTF-8"));FileUtils.setAttachmentResponseHeader(response, fileName);workbook.write(outputStream);outputStream.flush();outputStream.close();} catch (Exception e) {log.error("获取导入模板失败e={}", e.getMessage(), e);}}

http://www.ppmy.cn/news/1051574.html

相关文章

今天七夕,群友让我帮忙给他分配一个对象,于是我。。。

今天七夕&#xff0c;群友让我帮忙给他分配一个对象&#xff0c;于是我只好尝试给他分配对象了&#xff1a; CGirlFrined *pGF new CGirlFrined("大屌萌妹");int nRet (群友).SetGirlFriend(pGF);if (nRet ! 0) {alert("分配失败&#xff01;"); }后来觉…

leetcode303. 区域和检索 - 数组不可变(java)

前缀和数组的应用 区域和检索 - 数组不可变题目描述前缀和数组代码演示 区域和检索 - 数组不可变 难度 - 简单 原题链接 - 区域和检索 - 数组不可变 题目描述 给定一个整数数组 nums&#xff0c;处理以下类型的多个查询: 计算索引 left 和 right &#xff08;包含 left 和 righ…

Flask-SocketIO和Flask-Login联合开发socketio权限系统

设置 Flask, Flask-SocketIO, Flask-Login: 首先&#xff0c;确保安装了必要的库: pip install Flask Flask-SocketIO Flask-Login基础设置: from flask import Flask, render_template, redirect, url_for, request from flask_socketio import SocketIO, emit from flask_…

“深入理解Java虚拟机(JVM):背后的工作原理解析“

标题&#xff1a;深入理解Java虚拟机&#xff08;JVM&#xff09;&#xff1a;背后的工作原理解析 摘要&#xff1a;本文将深入探讨Java虚拟机&#xff08;JVM&#xff09;的工作原理&#xff0c;包括内存管理、垃圾回收、即时编译器等关键概念&#xff0c;以及如何优化代码以…

2023网络建设与运维模块三:服务搭建与运维

任务描述: 随着信息技术的快速发展,集团计划2023年把部分业务由原有的X86架构服务器上迁移到ARM架构服务器上,同时根据目前的部分业务需求进行了部分调整和优化。 一、X86架构计算机操作系统安装与管理 1.PC1系统为ubuntu-desktop-amd64系统(已安装,语言为英文),登录用户…

Kamailio branch基础知识

这里讲的都是kamailio很基础的知识 $ru "sip:192.168.1.100"; t_relay(); exit; 这是最简单的路由&#xff0c;这段路由创建了一个branch&#xff0c;叫main branch 下面这段复杂了一点点&#xff1a; $du "sip:192.168.1.100"; $ru "sip:a…

怎么画思维导图?教你几个绘制小妙招

怎么画思维导图&#xff1f;思维导图是一种非常有效的学习和思考工具。它可以帮助人们更好地组织和表达想法&#xff0c;从而更加清晰地思考问题。但是&#xff0c;很多人并不知道如何画思维导图。下面这篇文章&#xff0c;就给大家介绍一些绘制思维导图的小技巧。 今天要给大家…

Error Handling

有几个特定的异常类允许用户代码对与CAN总线相关的特定场景做出反应: Exception (Python standard library)+-- ...+-- CanError (python-can)+-- CanInterfaceNotImplementedError+-- CanInitializationError