Java如何使用POI操作Excel
发表于:2025-02-19 作者:千家信息网编辑
千家信息网最后更新 2025年02月19日,这篇文章主要介绍了Java如何使用POI操作Excel,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Java使用POI操作Excel1
千家信息网最后更新 2025年02月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安全错误
数据库的锁怎样保障安全
数据库只要作用
如何学好通信网络技术
传奇服务器怎么删除数据重新开区
数据库如何十六进制加密
网络安全仿真
vc 服务器安装
在数据库中创建员工表视频
360安全云盘服务器升级
成都网络安全培训学院
张永奎数据库原理与设计
应用软件开发前途
不同的战斗服务器
冠俊互联网科技有限公司
lol艾欧尼亚服务器截图
阿里云 主从数据库
硕博论文文摘型数据库
四川服务器阵列卡启动云空间
中学生护苗网络安全教育
tcp ip网络安全测试
外部备份服务器数据库
读取数据库文件
好点服务器
网络安全之电子商务网络安全
化工管道技术员数据库整理怎么做
软件开发面试时自我介绍范文
株洲java软件开发培训
服务器为什么要放到机房里
html提取字典数据库
文件能上传数据库吗
mcgs触摸屏与数据库