Java如何使用POI操作Excel
发表于:2025-02-21 作者:千家信息网编辑
千家信息网最后更新 2025年02月21日,这篇文章主要介绍了Java如何使用POI操作Excel,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Java使用POI操作Excel1
千家信息网最后更新 2025年02月21日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安全错误
数据库的锁怎样保障安全
苹果手机更新了以后无服务器
国外工控网络安全架构
经营范围写软件开发
移动网络安全实验报告
逃离塔科夫俄服怎么玩别的服务器
广西刀片服务器
电子交易的网络安全不包括
组网与网络安全计算题
苹果系统服务器未响应
ark服务器管理器
数据库文件缓存技术
人工智能软件开发好就业吗
正规的浪潮服务器销售电话多少
网络安全信息年初工作会
邯郸前端软件开发哪里好
企业网络安全政策的应对措施
浙江专业网络技术服务代理商
数据库用户权限表
服务器回复数据多少钱
汕头餐饮软件开发公司
虚拟服务器管理软件供应商
仓库数据库入库表
服务器网卡和交换机哪个好
销售实时数据库价格
在线教育直播平台软件开发
刀剑神域网络技术
vlan 认证服务器
网络安全模式断网了
国家电网湖南网络安全服务
梦幻西游手游ios服务器