jxl导入/导出Excel(Maven)
jxl && POI
jxl是一个开源的Java Excel API项目,通过Jxl,Java可以很方便的操作微软的Excel文档。除了Jxl之外,还有Apache的一个POI项目,也可以操作Excel,两者相比之下:Jxl使用方便,但功能相对POI比较弱,很多时候,一个软件应用程序需要生成Microsoft Excel文件格式的报告。有时,一个应用程序甚至希望将Excel文件作为输入数据。例如,一个公司开发的应用程序将财务部门需要所有输出生成自己的Excel。
Apache POI是一种流行的API,它允许程序员使用Java程序创建,修改和显示MS Office文件。这由Apache软件基金会开发使用Java分布式设计或修改Microsoft Office文件的开源库。它包含类和方法对用户输入数据或文件到MS Office文档进行解码。
jxl是一个开源的Java Excel API项目,通过Jxl,Java可以很方便的操作微软的Excel文档。除了Jxl之外,还有Apache的一个POI项目,也可以操作Excel,两者相比之下:Jxl使用方便,但功能相对POI比较弱,很多时候,一个软件应用程序需要生成Microsoft Excel文件格式的报告。有时,一个应用程序甚至希望将Excel文件作为输入数据。例如,一个公司开发的应用程序将财务部门需要所有输出生成自己的Excel。
Apache POI是一种流行的API,它允许程序员使用Java程序创建,修改和显示MS Office文件。这由Apache软件基金会开发使用Java分布式设计或修改Microsoft Office文件的开源库。它包含类和方法对用户输入数据或文件到MS Office文档进行解码。
使用jxl导出excel
使用jxl导出Excel 首先先在pom.xml添加依赖
<!--jxl--> <dependency> <groupId>net.sourceforge.jexcelapi</groupId> <artifactId>jxl</artifactId> <version>2.6.12</version> </dependency>
前台界面
我们现在需要在页面上点击导出Excel按钮就可以把表格导出来
接着需要在js文件实现exportFile函数
/*导出文件*/ exportFile: function () { window.location.href = "/underwrite_export.do" },
后台业务
这时js会跳转到url:underwrite_export.do
这时浏览器会根据域名查找 Spring会根据映射的url在Controller执行对应的方法
//==========导出Excel=========== @PermissionName("核保审核结果导出") @RequestMapping("/underwrite_export") @RequiresPermissions("underwrite:export") @ResponseBody public void exportFile(HttpServletResponse response) throws Exception { // 1.文件下载响应头 response.setHeader("Content-Disposition", "attachment;filename=underwrite.xls"); // 2.响应到浏览器 WritableWorkbook workbook = Workbook.createWorkbook(response.getOutputStream()); // 创建工作簿sheet WritableSheet sheet = workbook.createSheet("underwrite", 0); // 3.设置column名 sheet.addCell(new Label(0, 0, "承保机构")); sheet.addCell(new Label(1, 0, "申请单号")); sheet.addCell(new Label(2, 0, "产品名称")); sheet.addCell(new Label(3, 0, "投保人")); sheet.addCell(new Label(4, 0, "申请时间")); sheet.addCell(new Label(5, 0, "提交员工")); sheet.addCell(new Label(6, 0, "提交状态")); sheet.addCell(new Label(7, 0, "审核状态")); sheet.addCell(new Label(8, 0, "额度")); // 4.把核保的数据填充到工作簿中 service调用selectExport()查询数据库 List<UnderwriteWait> list = service.selectExport(); System.out.println(list.toArray()); try{ for (int i = 0, j = 1; i < list.size(); i++, j++) { UnderwriteWait underwrite = list.get(i); //System.out.println(underwrite); //设置列宽 sheet.setColumnView(i, 16); //重新设置部分列宽 sheet.setColumnView(3, 14); sheet.setColumnView(6, 10); sheet.setColumnView(7, 10); //设置行高 sheet.setRowView(i, 350); //设置字体的attribute WritableFont font1=new WritableFont(WritableFont.createFont("楷体 _GB2312"), 12, WritableFont.NO_BOLD); WritableCellFormat format1=new WritableCellFormat(font1); System.out.println(underwrite.getId()); sheet.addCell(new Label(0, j, underwrite.getOrg().getName(),format1)); sheet.addCell(new Label(1, j, underwrite.getApplyordernumber(),format1)); sheet.addCell(new Label(2, j, underwrite.getCarinsuranc().getInsName(),format1)); sheet.addCell(new Label(3, j, underwrite.getClient().getName(),format1)); String applydate=underwrite.getApplydate().toLocaleString().substring(0,9); sheet.addCell(new Label(4, j, applydate,format1)); sheet.addCell(new Label(5, j, underwrite.getEmployee().getRealname(),format1)); String stateApply=(underwrite.getStateApply().toString().equals("0")) ? "未审核":"已提交"; sheet.addCell(new Label(6, j,stateApply)); String stateAudit=(underwrite.getStateAudit().toString().equals("1")) ? "已提交":"已审核"; sheet.addCell(new Label(7, j, stateAudit)); sheet.addCell(new Label(8, j, underwrite.getAmount().toString(),format1)); }}catch (Exception e){ e.printStackTrace(); } // 5.写入数据 workbook.write(); // 6.关闭资源 workbook.close(); }
这时我们就把jxl导出excel的功能做完了


jxl导入Excel
js文件
/*导入文件*/ importFile: function () { /*清空表单*/ $("#underwrite_file").form("clear"); /*打开弹出框*/ $("#underwrite_file").dialog("open"); }
后台Controller
@PermissionName("资料导入") @RequestMapping("/underwrite_import") @RequiresPermissions("underwrite:import") public String importFile(MultipartFile file) throws Exception { // 1.获取用户上传的文件 Workbook workbook = Workbook.getWorkbook(file.getInputStream()); // 2.获取工作簿sheet Sheet sheet = workbook.getSheet(0); // 3.获取总行数 int rows = sheet.getRows(); for (int i = 1; i < rows; i++) { Underwrite underwrite = new Underwrite(); underwrite.setXxx(sheet.getCell(0, i).getContents()); underwrite.setXxx(sheet.getCell(1, i).getContents()); employee.setXxx(sheet.getCell(2, i).getContents()); employee.setEmail(sheet.getCell(3, i).getContents()); // 4.添加到数据库中 service.insert(underwrite); } // 5.关闭资源 workbook.close(); return "underwrite"; }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
2018-08-24 oracle左连接与右连接