[Training Video - 6] [File Reading] [Java] Create and Write Excel File Using Apache POI API
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 | package com.file.properties; import java.io.File; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.util.ArrayList; import java.util.Collections; import java.util.Date; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.Set; import org.apache.poi.hssf.usermodel.HSSFSheet; import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.RichTextString; import org.apache.poi.ss.usermodel.Row; public class CreateNewExcel { static void createExcelFile(File createFile,String sheetName, Map<String, Object[]> data) { HSSFWorkbook workbook = new HSSFWorkbook(); HSSFSheet sheet = workbook.createSheet(sheetName); Set<String> keySet=data.keySet(); List<String> keyList= new ArrayList<String>(keySet); Collections.sort(keyList); int rownum = 0 ; for (String key : keyList) { Row row = sheet.createRow(rownum++); Object[] objArr = (Object[]) data.get(key); int cellnum = 0 ; for (Object obj : objArr) { Cell cell = row.createCell(cellnum++); if (obj instanceof Date) cell.setCellValue((RichTextString)obj); else if (obj instanceof Boolean) cell.setCellValue((Boolean)obj); else if (obj instanceof String) cell.setCellValue((String)obj); else if (obj instanceof Double) cell.setCellValue((Double)obj); } } try { FileOutputStream out = new FileOutputStream(createFile); workbook.write(out); out.close(); System.out.println( "Excel written successfully.." ); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } /** * @param args */ public static void main(String[] args) { File createFile = new File( "D:\\SoapUIStudy\\createExcelFile.xls" ); String sheetName = "Sample sheet" ; Map<String, Object[]> data = new HashMap<String, Object[]>(); data.put( "1" , new Object[] { "Emp No." , "Name" , "Salary" }); data.put( "2" , new Object[] {1d, "John" , 1500000d}); data.put( "3" , new Object[] {2d, "Sam" , 800000d}); data.put( "4" , new Object[] {3d, "Dean" , 700000d}); createExcelFile(createFile,sheetName,data); } } |
Result :
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 25岁的心里话
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现