




已阅读5页,还剩2页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
Apache POI HSSF和XSSF读写EXCEL总结 HSSF是指2007年以前的,XSSF是指2007年版本以上的 这个还是比较好用的,这些总结来自Apache的官方向导的点点滴滴 还有好多没有没有写的,详细的请参考/spreadsheet/quick-guide.html 还有LOG也比较好看 Java代码 1. publicclassSummaryHSSF 2. 3. publicstaticvoidmain(Stringargs)throwsIOException 4. /创建Workbook对象(这一个对象代表着对应的一个Excel文件) 5. /HSSFWorkbook表示以xls为后缀名的文件 6. Workbookwb=newHSSFWorkbook(); 7. /获得CreationHelper对象,这个应该是一个帮助类 8. CreationHelperhelper=wb.getCreationHelper(); 9. /创建Sheet并给名字(表示Excel的一个Sheet) 10. Sheetsheet1=wb.createSheet(HSSF_Sheet_1); 11. Sheetsheet2=wb.createSheet(HSSF_Sheet_2); 12. /Row表示一行Cell表示一列 13. Rowrow=null; 14. Cellcell=null; 15. for(inti=0;i60;i=i+2) 16. /获得这个sheet的第i行 17. row=sheet1.createRow(i); 18. /设置行长度自动 19. /row.setHeight(short)500); 20. row.setHeightInPoints(20); 21. /row.setZeroHeight(true); 22. for(intj=0;j25;j+) 23. /设置每个sheet每一行的宽度,自动,根据需求自行确定 24. sheet1.autoSizeColumn(j+1,true); 25. /创建一个基本的样式 26. CellStylecellStyle=SummaryHSSF.createStyleCell(wb); 27. /获得这一行的每j列 28. cell=row.createCell(j); 29. if(j=0) 30. /设置文字在单元格里面的位置 31. cellStyle=SummaryHSSF.setCellStyleAlignment(cellStyle,CellStyle.ALIGN_CENTER,CellStyle.VERTICAL_CENTER); 32. /先创建字体样式,并把这个样式加到单元格的字体里面 33. cellStyle.setFont(createFonts(wb); 34. /把这个样式加到单元格里面 35. cell.setCellStyle(cellStyle); 36. /给单元格设值 37. cell.setCellValue(true); 38. elseif(j=1) 39. /设置文字在单元格里面的位置 40. cellStyle=SummaryHSSF.setCellStyleAlignment(cellStyle,CellStyle.ALIGN_CENTER,CellStyle.VERTICAL_CENTER); 41. /设置这个样式的格式(Format) 42. cellStyle=SummaryHSSF.setCellFormat(helper,cellStyle,#,#0.0000); 43. /先创建字体样式,并把这个样式加到单元格的字体里面 44. cellStyle.setFont(createFonts(wb); 45. /把这个样式加到单元格里面 46. cell.setCellStyle(cellStyle); 47. /给单元格设值 48. cell.setCellValue(newDouble(2008.2008); 49. elseif(j=2) 50. cellStyle=SummaryHSSF.setCellStyleAlignment(cellStyle,CellStyle.ALIGN_CENTER,CellStyle.VERTICAL_CENTER); 51. cellStyle.setFont(createFonts(wb); 52. cell.setCellStyle(cellStyle); 53. cell.setCellValue(helper.createRichTextString(RichString+i+j); 54. elseif(j=3) 55. cellStyle=SummaryHSSF.setCellStyleAlignment(cellStyle,CellStyle.ALIGN_CENTER,CellStyle.VERTICAL_CENTER); 56. cellStyle=SummaryHSSF.setCellFormat(helper,cellStyle,MM-yyyy-dd); 57. cell.setCellStyle(cellStyle); 58. cell.setCellValue(newDate(); 59. elseif(j=24) 60. cellStyle=SummaryHSSF.setCellStyleAlignment(cellStyle,CellStyle.ALIGN_CENTER,CellStyle.VERTICAL_CENTER); 61. cellStyle.setFont(createFonts(wb); 62. /设置公式 63. cell.setCellFormula(SUM(E+(i+1)+:X+(i+1)+); 64. else 65. cellStyle=SummaryHSSF.setCellStyleAlignment(cellStyle,CellStyle.ALIGN_CENTER,CellStyle.VERTICAL_CENTER); 66. cellStyle=SummaryHSSF.setFillBackgroundColors(cellStyle,IndexedColors.ORANGE.getIndex(),IndexedColors.ORANGE.getIndex(),CellStyle.SOLID_FOREGROUND); 67. cell.setCellStyle(cellStyle); 68. cell.setCellValue(1); 69. 70. 71. 72. /输出 73. OutputStreamos=newFileOutputStream(newFile(c:/SummaryHSSF.xls); 74. wb.write(os); 75. os.close(); 76. 77. /* 78. *边框 79. *paramwb 80. *return 81. */82. publicstaticCellStylecreateStyleCell(Workbookwb) 83. CellStylecellStyle=wb.createCellStyle(); 84. /设置一个单元格边框颜色 85. cellStyle.setBorderBottom(CellStyle.BORDER_THIN); 86. cellStyle.setBorderTop(CellStyle.BORDER_THIN); 87. cellStyle.setBorderLeft(CellStyle.BORDER_THIN); 88. cellStyle.setBorderRight(CellStyle.BORDER_THIN); 89. /设置一个单元格边框颜色 90. cellStyle.setRightBorderColor(IndexedColors.BLACK.getIndex(); 91. cellStyle.setLeftBorderColor(IndexedColors.BLACK.getIndex(); 92. cellStyle.setBottomBorderColor(IndexedColors.BLACK.getIndex(); 93. cellStyle.setTopBorderColor(IndexedColors.BLACK.getIndex(); 94. returncellStyle; 95. 96. /* 97. *设置文字在单元格里面的位置 98. *CellStyle.ALIGN_CENTER 99. *CellStyle.VERTICAL_CENTER 100. *paramcellStyle 101. *paramhalign 102. *paramvalign 103. *return 104. */105. publicstaticCellStylesetCellStyleAlignment(CellStylecellStyle,shorthalign,shortvalign) 106. /设置上下 107. cellStyle.setAlignment(CellStyle.ALIGN_CENTER); 108. /设置左右 109. cellStyle.setVerticalAlignment(CellStyle.VERTICAL_CENTER); 110. returncellStyle; 111. 112. /* 113. *格式化单元格 114. *如#,#0.00,m/d/yy去HSSFDataFormat或XSSFDataFormat里面找 115. *paramcellStyle 116. *paramfmt 117. *return 118. */119. publicstaticCellStylesetCellFormat(CreationHelperhelper,CellStylecellStyle,Stringfmt) 120. /还可以用其它方法创建format 121. cellStyle.setDataFormat(helper.createDataFormat().getFormat(fmt); 122. returncellStyle; 123. 124. /* 125. *前景和背景填充的着色 126. *paramcellStyle 127. *parambgIndexedColors.ORANGE.getIndex(); 128. *paramfgIndexedColors.ORANGE.getIndex(); 129. *paramfpCellStyle.SOLID_FOREGROUND 130. *return 131. */132. publicstaticCellStylesetFillBackgroundColors(CellStylecellStyle,shortbg,shortfg,shortfp) 133. /cellStyle.setFillBackgroundColor(bg); 134. cellStyle.setFillForegroundColor(fg); 135. cellStyle.setFillPattern(fp); 136. returncellStyle; 137. 138. /* 139. *设置字体 140. *paramwb 141. *return 142. */143. publicstaticFontcreateFonts(Workbookwb) 144. /创建Font对象 145. Fontfont=wb.createFont(); 146. /设置字体 147. font.setFontName(黑体); 148. /着色 149. font.setColor(HSSFColor.BLUE.index); 150. /斜体 151. font.setItalic(true); 152. /字体大小 153. font.setFontHeight(short)300); 154. returnfont; 155. 156. public class SummaryHSSF public static void main(String args) throws IOException /创建Workbook对象(这一个对象代表着对应的一个Excel文件) /HSSFWorkbook表示以xls为后缀名的文件Workbook wb = new HSSFWorkbook();/获得CreationHelper对象,这个应该是一个帮助类CreationHelper helper = wb.getCreationHelper();/创建Sheet并给名字(表示Excel的一个Sheet)Sheet sheet1 = wb.createSheet(HSSF_Sheet_1);Sheet sheet2 = wb.createSheet(HSSF_Sheet_2);/Row表示一行Cell表示一列Row row = null;Cell cell = null;for(int i=0;i60;i=i+2)/获得这个sheet的第i行row = sheet1.createRow(i);/设置行长度自动/row.setHeight(short)500);row.setHeightInPoints(20);/row.setZeroHeight(true);for(int j=0;j25;j+)/设置每个sheet每一行的宽度,自动,根据需求自行确定sheet1.autoSizeColumn(j+1, true);/创建一个基本的样式CellStyle cellStyle = SummaryHSSF.createStyleCell(wb);/获得这一行的每j列cell = row.createCell(j);if(j=0)/设置文字在单元格里面的位置cellStyle = SummaryHSSF.setCellStyleAlignment(cellStyle, CellStyle.ALIGN_CENTER, CellStyle.VERTICAL_CENTER);/先创建字体样式,并把这个样式加到单元格的字体里面cellStyle.setFont(createFonts(wb);/把这个样式加到单元格里面cell.setCellStyle(cellStyle);/给单元格设值cell.setCellValue(true);else if(j=1)/设置文字在单元格里面的位置cellStyle = SummaryHSSF.setCellStyleAlignment(cellStyle, CellStyle.ALIGN_CENTER, CellStyle.VERTICAL_CENTER);/设置这个样式的格式(Format)cellStyle = SummaryHSSF.setCellFormat(helper,cellStyle, #,#0.0000);/先创建字体样式,并把这个样式加到单元格的字体里面cellStyle.setFont(createFonts(wb);/把这个样式加到单元格里面cell.setCellStyle(cellStyle);/给单元格设值cell.setCellValue(new Double(2008.2008);else if(j=2)cellStyle = SummaryHSSF.setCellStyleAlignment(cellStyle, CellStyle.ALIGN_CENTER, CellStyle.VERTICAL_CENTER);cellStyle.setFont(createFonts(wb);cell.setCellStyle(cellStyle);cell.setCellValue(helper.createRichTextString(RichString+i+j);else if(j=3)cellStyle = SummaryHSSF.setCellStyleAlignment(cellStyle, CellStyle.ALIGN_CENTER, CellStyle.VERTICAL_CENTER);cellStyle = SummaryHSSF.setCellFormat(helper,cellStyle, MM-yyyy-dd);cell.setCellStyle(cellStyle);cell.setCellValue(new Date();else if(j=24)cellStyle = SummaryHSSF.setCellStyleAlignment(cellStyle, CellStyle.ALIGN_CENTER, CellStyle.VERTICAL_CENTER);cellStyle.setFont(createFonts(wb);/设置公式cell.setCellFormula(SUM(E+(i+1)+:X+(i+1)+);elsecellStyle = SummaryHSSF.setCellStyleAlignment(cellStyle, CellStyle.ALIGN_CENTER, CellStyle.VERTICAL_CENTER);cellStyle = SummaryHSSF.setFillBackgroundColors(cellStyle,IndexedColors.ORANGE.getIndex(),IndexedColors.ORANGE.getIndex(),CellStyle.SOLID_FOREGROUND);cell.setCellStyle(cellStyle);cell.setCellValue(1);/输出OutputStream os = new FileOutputStream(new File(c:/SummaryHSSF.xls);wb.write(os);os.close();/* * 边框 * param wb * return */public static CellStyle createStyleCell(Workbook wb)CellStyle cellStyle = wb.createCellStyle();/设置一个单元格边框颜色cellStyle.setBorderBottom(CellStyle.BORDER_THIN);cellStyle.setBorderTop(CellStyle.BORDER_THIN);cellStyle.setBorderLeft(CellStyle.BORDER_THIN);cellStyle.setBorderRight(CellStyle.BORDER_THIN);/设置一个单元格边框颜色cellStyle.setRightBorderColor(IndexedColors.BLACK.getIndex();cellStyle.setLeftBorderColor(IndexedColors.BLACK.getIndex();cellStyle.setBottomBorderColor(IndexedColors.BLACK.getIndex();cellStyle.setTopBorderColor(IndexedColors.BLACK.getIndex();return cellStyle;/* * 设置文字在单元格里面的位置 * CellStyle.ALIGN_CENTER * CellStyle.VERTICAL_CENTER * param cellStyle * param halign * param valign * return */public static CellStyle setCellStyleAlignment(CellStyle cellStyle,short halign,short valign)/设置上下cellStyle.setAlignment(CellStyle.ALIGN_CENTER);/设置左右cellStyle.setVerticalAlignment(CellStyle.VERTICAL_CENTER);return cellStyle;/* * 格式化单元格 * 如#,#0.00,m/d/yy去HSSFDataFormat或XSSFDataFormat里面找 * param cellStyle * param fmt * return */public static CellStyle setCellFormat(CreationHelper helper,CellStyle cellStyle,String fmt)/还可以用其它方法创建formatcellStyle.setDataFormat(helper.createDataFormat().getFormat(fmt);return cellStyle;/* * 前景和背景填充的着色 * param cellStyle * param bg IndexedColors.ORANGE.getIndex(); * param fg IndexedColors.ORANGE.getIndex(); * param fp CellStyle.SOLID_FOREGROUND * return */public static CellStyle setFillBackgroundColors(CellStyle cellStyle,short bg,short fg,short fp)/cellStyle.setFillBackgroundColor(bg);cellStyle.setFillForegroundColor(fg);cellStyle.setFillPattern(fp);return cellStyle;/* * 设置字体 * param wb * return */public static Font createFonts(Workbook wb)/创建Font对象Font font = wb.createFont();/设置字体font.setFontName(黑体);/着色font.setColor(HSSFColor.BLUE.index);/斜体font.setItalic(true);/字体大小font.setFontHeight(short)300);return font;读取Excel文件 Java代码 1. publicclassReadExcel 2. publicstaticvoidmain(Stringargs)throwsException 3. InputStreamis=newFileInputStream(newFile(c:/SummaryHSSF.xls); 4. /根据输入流创建Workbook对象 5. Workbookwb=WorkbookFactory.create(is); 6. /get到Sheet对象 7. Sheetsheet=wb.getSheetAt(0); 8. /这个必须用接口 9. for(Rowrow:sheet) 10. for(Cellcell:row) 11. /cell.getCellType是获得cell里面保存的值的type 12. /如Cell.CELL_TYPE_STRING 13. switch(cell.getCellType() 14. caseCell.CELL_TYPE_BOOLEAN: 15. /得到Boolean对象的方法 16. System.out.print(cell.getBooleanCellValue()+); 17. break; 18. caseCell.CELL_TYPE_NUMERIC: 19. /先看是否是日期格式 20. if(DateUtil.isCellDateFormatted(cell) 21. /读取日期格式 22. System.out.print(cell.getDateCellValue()+); 23. else 24. /读取数字 25. System.out.print(cell.getNumericCellValue()+); 26. 27. break; 28. caseCell.CELL_TYPE_FORMULA: 29. /读取公式 30. System.out.print(cell.getCellFormula()+); 31. break; 32. caseCell.CELL_TYPE_STRING: 33. /读取String 34. System.out.print(cell.getRichStringCellValue().toString()+); 35. break; 36. 37. 38. System.out.println(); 39. 40. 41. public class ReadExcel public static void main(String args) throws Exception InputStream is = new FileInputStream(new File(c:/SummaryHSSF.xls);/根据输入流创建Workbook对象Workboo
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 建筑装饰工程施工合同
- 聘用临时人员合同2篇
- 瑞氏染色原理步骤课件
- 东莞大型工程保洁方案(3篇)
- 安全文明样板工地培训课件
- 典型工程的材料方案(3篇)
- 桂平市中沙镇新安落窝山矿区陶瓷土项目环境影响报告表
- 班级同学集体生日课件
- 猫虎歌课件教学课件
- 非标工程灯具订制方案(3篇)
- 2025重庆市专业应急救援总队应急救援人员招聘28人考试参考题库及答案解析
- 2025年国际贸易业务员招聘考试试题集及答案
- 2025年建筑涂料采购专项合同
- 高考化学一轮复习:硫及其化合物(好题冲关)原卷版
- 2025年城市环境监测评估标准评估方案
- 2025年水面渔业养殖承包合同范本:水产养殖合作协议
- 水厂反恐知识培训内容课件
- 供应链金融操作指南
- 部编版语文六年级上册3《古诗词三首》(同步练习)(含答案)
- 2025-2026学年湘教版(2024)初中地理七年级上册教学计划及进度表
- 2025年重庆八中宏帆中学小升初自主招生数学试题(含答案详解)
评论
0/150
提交评论