Java如何使用POI操作Excel
发表于:2025-01-19 作者:千家信息网编辑
千家信息网最后更新 2025年01月19日,这篇文章主要介绍了Java如何使用POI操作Excel,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Java使用POI操作Excel1
千家信息网最后更新 2025年01月19日Java如何使用POI操作Excel
这篇文章主要介绍了Java如何使用POI操作Excel,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
Java使用POI操作Excel
1. POI操作Excel
1.1. 依赖
org.apache.poi poi 4.1.0 org.apache.poi poi-ooxml 4.1.0 org.apache.poi poi-ooxml-schemas 4.1.0
1.2. 读取Excel
1.2.1. Excel文件内容
1.2.2. 代码
/** * 读取excel */ public static void readExcel() { InputStream inputStream = null; XSSFWorkbook xssfWorkbook = null; try { String past = "/操作excel.xlsx"; inputStream = new FileInputStream(past); xssfWorkbook = new XSSFWorkbook(inputStream); //获取sheet的个数 int numberOfSheets = xssfWorkbook.getNumberOfSheets(); //获取指定的sheet System.out.println(numberOfSheets); //通过指定名称获取 XSSFSheet sheet = xssfWorkbook.getSheet("笔记本"); //通过下标获取 XSSFSheet sheetAt = xssfWorkbook.getSheetAt(1); if (sheetAt != null) { //最后一行有数据的 int lastRowNum = sheetAt.getLastRowNum(); XSSFRow row; short lastCellNum; XSSFCell cell; for (int i = 0; i <= lastRowNum; i++) { //获取指定行 row = sheetAt.getRow(i); if (row == null) { continue; } //最后一列有数据的 lastCellNum = row.getLastCellNum(); for (int j = 0; j <= lastCellNum; j++) { cell = row.getCell(j); if (cell == null) { continue; } //数据类型 CellType cellType = cell.getCellType(); //字符串 if (CellType.STRING == cellType) { System.out.println(cell.toString()); } //数字 else if (CellType.NUMERIC == cellType) { try { System.out.println(cell.getDateCellValue()); } catch (Exception e) { System.out.println(cell.toString()); } } //…… else { System.out.println(cell.toString()); } } } } } catch (Exception e) { e.printStackTrace(); } finally { if (inputStream != null) { try { inputStream.close(); } catch (IOException e) { e.printStackTrace(); } } } }
1.2.3. 控制台输出结果
2便签名称便签分类创建时间创建人拥有人小明的便签学习便签Tue Sep 03 00:00:00 CST 2019小明小明小明的个人便签个人便签Sun Sep 08 00:00:00 CST 2019小明小明
1.3. 生成excel
1.3.1. 代码
/** * 生成excel */ public static void creatExcel() { XSSFWorkbook xssfWorkbook = new XSSFWorkbook(); //创建一个sheet XSSFSheet sheet1 = xssfWorkbook.createSheet("第一个新建的sheet"); //设置高度和宽度,也可以每行每列单独分开设置 //参数为字符个数 sheet1.setDefaultColumnWidth(20); sheet1.setDefaultRowHeight((short) (33 * 20)); //第二个参数为字符宽度的1/256 sheet1.setColumnWidth(5, 30 * 256); //设置单元格样式 XSSFCellStyle cellStyle = xssfWorkbook.createCellStyle(); // 字体样式 Font fontStyle = xssfWorkbook.createFont(); fontStyle.setBold(true); // 字体 fontStyle.setFontName("等线"); // 大小 fontStyle.setFontHeightInPoints((short) 11); // 将字体样式添加到单元格样式中 cellStyle.setFont(fontStyle); //水平居中 cellStyle.setAlignment(HorizontalAlignment.CENTER); //垂直居中 cellStyle.setVerticalAlignment(VerticalAlignment.CENTER); //设置 单元格填充色 DefaultIndexedColorMap defaultIndexedColorMap = new DefaultIndexedColorMap(); XSSFColor clr = new XSSFColor(defaultIndexedColorMap); byte[] bytes = { (byte) 217, (byte) 217, (byte) 217 }; clr.setRGB(bytes); cellStyle.setFillPattern(FillPatternType.SOLID_FOREGROUND); cellStyle.setFillForegroundColor(clr); //设置单元格不为锁定,可编辑,反是用了这个样式的都可编辑 cellStyle.setLocked(false); //锁定整个sheet不可编辑 sheet1.protectSheet("1231312"); //创建一行数据 XSSFRow row; XSSFCell cell; row = sheet1.createRow(0); cell = row.createCell(0); //设值 cell.setCellValue("2"); //合并单元格 CellRangeAddress cra = new CellRangeAddress(1, 1, 0, 3); // 起始行, 终止行, 起始列, 终止列 sheet1.addMergedRegion(cra); //设置合并单元格的样式 // 使用RegionUtil类为合并后的单元格添加边框 // 下边框 RegionUtil.setBorderBottom(BorderStyle.MEDIUM_DASHED, cra, sheet1); // 左边框 RegionUtil.setBorderLeft(BorderStyle.MEDIUM_DASHED, cra, sheet1); row = sheet1.getRow(1); //设置合并单元格内的文本样式 //但这个单元格的边框样式会覆盖上面设置的合并单元格的样式 CellUtil.getCell(row, 0).setCellStyle(cellStyle); //设置单个单元格的样式 row = sheet1.createRow(2); cell = row.createCell(0); cell.setCellStyle(cellStyle); //设置数据校验 //序列校验 String[] strArray = { "星期一", "星期二", "星期三" }; XSSFDataValidationHelper dvHelper = new XSSFDataValidationHelper((XSSFSheet) sheet1); XSSFDataValidationConstraint dvConstraint = (XSSFDataValidationConstraint) dvHelper.createExplicitListConstraint(strArray); CellRangeAddressList addressList = new CellRangeAddressList(3, 3, 0, 2); XSSFDataValidation validation = (XSSFDataValidation) dvHelper.createValidation(dvConstraint, addressList); //显示报错提示框 validation.setShowErrorBox(true); validation.createErrorBox("错误提示", "只能选择指定的内容!"); //设置单元格右侧显示剪头符号,显示可用的选项,默认为true validation.setSuppressDropDownArrow(true); //显示提示信息 validation.setShowPromptBox(true); validation.createPromptBox("提示信息", "请选择星期填入!"); sheet1.addValidationData(validation); //保护工作薄不可被修改 xssfWorkbook.lockStructure(); //这个不知道有啥用 xssfWorkbook.lockRevision(); //锁定excel的窗口大小,不能无限制的横向,纵向拉伸。 xssfWorkbook.lockWindows(); xssfWorkbook.createSheet("第二个人sheet"); OutputStream outputStream = null; try { outputStream = new FileOutputStream("/创建excel.xlsx"); xssfWorkbook.write(outputStream); outputStream.flush(); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } finally { if (outputStream != null) { try { outputStream.close(); } catch (IOException e) { e.printStackTrace(); } } } }
1.3.2. 生成excel文件内容
感谢你能够认真阅读完这篇文章,希望小编分享的"Java如何使用POI操作Excel"这篇文章对大家有帮助,同时也希望大家多多支持,关注行业资讯频道,更多相关知识等着你来学习!
单元
样式
便签
小明
数据
星期
篇文章
提示
内容
字体
字符
边框
生成
一行
个人
个数
代码
信息
参数
名称
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
英国国家卫生服务部卫生经济学评价数据库
如何用c 开发个软件开发
安装保密系统后 数据库
服务器管理里面没有用户和组
城关网络安全责任
网络安全性能漏洞
服务器链接
个人谈网络安全
嵌入式软件开发工程师dsp
拷贝网络安全设备
上海车团网络技术
区块链网络技术实施方案
我的世界服务器垃圾管理
战队服务器连接出现波动
电信服务器维护电话
学校机房无网络服务器
阿里云服务器联网
广州企帮网络技术有限公司
软件开发什么时候可以验收
spss软件开发公司
100w数据插入数据库
设计中的网络安全
曙光服务器修改启动方式
阿卡索总部软件开发
网络安全手画图画
安徽越岭互联网科技有限公司
淘门网络技术
计算机网络技术实验周报
分布式轻量级数据库
软件开发工程师的称呼