- 浏览: 520222 次
- 性别:
- 来自: 深圳
文章分类
- 全部博客 (299)
- Oracle(pl/sql_Erp_Pro*C) (69)
- 设计模式 (4)
- spring (23)
- ext (17)
- apache开源项目应用 (4)
- jquery (16)
- 生活琐事 (8)
- 下载资源 (23)
- mysql (2)
- Eclipse使用积累 (5)
- 报表类(报表/图表) (13)
- php (4)
- Web多彩文本框 (3)
- json (4)
- jqgrid (2)
- ant (2)
- java算法积累 (8)
- EL表达式/JSTL (4)
- poi (3)
- gwt (2)
- 爬网第一步 (2)
- javascript (17)
- Javaweb (8)
- tomcat (1)
- flex (1)
- Java&DB (3)
- J2SE (7)
- linux (3)
- 数据结构 (1)
- dot net (5)
- struts (1)
- ibatis (1)
- log4j (1)
- 项目管理 (1)
- Java native interface(jni,jacob......) (5)
- applet (1)
- VB.net/C#.net/JNI (20)
- css (1)
- Sqlite (1)
- servlet (1)
- REST (1)
最新评论
-
wenhurena:
能不能给一下解压密码roki.work.2017@gmail. ...
Ebs解体新書と学習資料1 -
liutao1600:
楼主写的太好了,每天学习~~
Spring_MVC(6)测试 -
liutao1600:
太好了,每天学习你的文章~~~
Spring_MVC(3)表单页面处理 -
liutao1600:
学习了,太好了
Spring_MVC(2)控制层处理 -
liutao1600:
学习了~~~
Spring_MVC(1)构建简单web应用
Apache POI HSSF和XSSF读写EXCEL总结
HSSF是指2007年以前的,XSSF是指2007年版本以上的
这个还是比较好用的,这些总结来自Apache的官方向导的点点滴滴
还有好多没有没有写的,详细的请参考http://poi.apache.org/spreadsheet/quick-guide.html
还有LOG也比较好看
- 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;i<60;i=i+2){
- //获得这个sheet的第i行
- row = sheet1.createRow(i);
- //设置行长度自动
- //row.setHeight((short)500);
- row.setHeightInPoints(20);
- //row.setZeroHeight(true);
- for(int j=0;j<25;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)+")");
- }else{
- cellStyle = 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){
- //还可以用其它方法创建format
- cellStyle.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;
- }
- }
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;i<60;i=i+2){ //获得这个sheet的第i行 row = sheet1.createRow(i); //设置行长度自动 //row.setHeight((short)500); row.setHeightInPoints(20); //row.setZeroHeight(true); for(int j=0;j<25;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)+")"); }else{ cellStyle = 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){ //还可以用其它方法创建format cellStyle.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文件
- public class ReadExcel {
- public static void main(String[] args) throws Exception {
- InputStream is = new FileInputStream(new File("c://SummaryHSSF.xls"));
- //根据输入流创建Workbook对象
- Workbook wb = WorkbookFactory.create(is);
- //get到Sheet对象
- Sheet sheet = wb.getSheetAt(0);
- //这个必须用接口
- for(Row row : sheet){
- for(Cell cell : row){
- //cell.getCellType是获得cell里面保存的值的type
- //如Cell.CELL_TYPE_STRING
- switch(cell.getCellType()){
- case Cell.CELL_TYPE_BOOLEAN:
- //得到Boolean对象的方法
- System.out.print(cell.getBooleanCellValue()+" ");
- break;
- case Cell.CELL_TYPE_NUMERIC:
- //先看是否是日期格式
- if(DateUtil.isCellDateFormatted(cell)){
- //读取日期格式
- System.out.print(cell.getDateCellValue()+" ");
- }else{
- //读取数字
- System.out.print(cell.getNumericCellValue()+" ");
- }
- break;
- case Cell.CELL_TYPE_FORMULA:
- //读取公式
- System.out.print(cell.getCellFormula()+" ");
- break;
- case Cell.CELL_TYPE_STRING:
- //读取String
- System.out.print(cell.getRichStringCellValue().toString()+" ");
- break;
- }
- }
- System.out.println("");
- }
- }
- }
public class ReadExcel { public static void main(String[] args) throws Exception { InputStream is = new FileInputStream(new File("c://SummaryHSSF.xls")); //根据输入流创建Workbook对象 Workbook wb = WorkbookFactory.create(is); //get到Sheet对象 Sheet sheet = wb.getSheetAt(0); //这个必须用接口 for(Row row : sheet){ for(Cell cell : row){ //cell.getCellType是获得cell里面保存的值的type //如Cell.CELL_TYPE_STRING switch(cell.getCellType()){ case Cell.CELL_TYPE_BOOLEAN: //得到Boolean对象的方法 System.out.print(cell.getBooleanCellValue()+" "); break; case Cell.CELL_TYPE_NUMERIC: //先看是否是日期格式 if(DateUtil.isCellDateFormatted(cell)){ //读取日期格式 System.out.print(cell.getDateCellValue()+" "); }else{ //读取数字 System.out.print(cell.getNumericCellValue()+" "); } break; case Cell.CELL_TYPE_FORMULA: //读取公式 System.out.print(cell.getCellFormula()+" "); break; case Cell.CELL_TYPE_STRING: //读取String System.out.print(cell.getRichStringCellValue().toString()+" "); break; } } System.out.println(""); } } }
还有一种传统的读法
- Sheet sheet = wb.getSheetAt(0);
- for (Iterator rit = sheet.rowIterator(); rit.hasNext(); ) {
- Row row = (Row)rit.next();
- for (Iterator cit = row.cellIterator(); cit.hasNext(); ) {
- Cell cell = (Cell)cit.next();
- // Do something here
- }
- }
- HSSFSheet sheet = wb.getSheetAt(0);
- for (Iterator<HSSFRow> rit = (Iterator<HSSFRow>)sheet.rowIterator(); rit.hasNext(); ) {
- HSSFRow row = rit.next();
- for (Iterator<HSSFCell> cit = (Iterator<HSSFCell>)row.cellIterator(); cit.hasNext(); ) {
- HSSFCell cell = cit.next();
- // Do something here
- }
- }
相关推荐
Apache POI 是一个用于读取和写入 Microsoft Office 格式文件(如 Word 和 Excel)的开源 Java 库。它支持多种格式,包括旧版的二进制格式(例如 .xls 文件)和较新的基于 XML 的格式(例如 .xlsx 文件)。本指南将...
总结来说,Apache POI的HSSF和XSSF组件为Java开发者提供了一个强大且灵活的工具,用于处理Excel文件。它们使得在Java应用程序中读写Excel变得非常简单,无论是传统的.xls文件还是现代的.xlsx文件。通过学习和掌握...
在实际使用中,Apache POI提供了一系列的接口和类,例如`Workbook`(工作簿)、`Sheet`(工作表)、`Row`(行)和`Cell`(单元格),开发者可以通过这些对象来创建、修改和读取Excel文件。例如,创建一个新的工作簿...
Apache POI项目提供了HSSF和XSSF两个模块,分别用于操作旧版的Excel文件(.xls)和新版的Excel文件(.xlsx)。HSSF代表Horrible Spreadsheet Format,是针对Excel 97-2003文件格式的实现;而XSSF代表XML Spreadsheet...
提供多种API:Apache POI库提供了多种API,包括HSSF、XSSF、HWPF、XWPF、HSLF和XSLF等。这些API可以帮助开发人员处理不同类型的Office文档,例如HSSF可以处理Excel 97-2003格式的电子表格,XSSF可以处理Excel 2007...
Apache POI 是一个广泛使用的Java库,用于读写Microsoft Office格式的文件,特别是Excel。它提供了两种主要的接口,HSSF(Horrible Spreadsheet Format)和XSSF(XML Spreadsheet Format),分别用于处理老版本的....
总结,Apache POI是Java开发中处理Excel文件的强大工具,涵盖了从基本的读写操作到复杂的格式设置和公式计算。通过熟练掌握Apache POI,开发者可以构建灵活且高效的Excel处理程序,满足各种业务需求。
1. **HSSF API**:这是Apache POI提供用于读写旧版Excel文件的接口。HSSF模型允许开发者操作工作簿(Workbook)、工作表(Sheet)、行(Row)、单元格(Cell)等对象,进行数据的读取和写入。 2. **XSSF API**:...
在处理大型Excel文件时,传统的HSSF和XSSF模型可能会遇到性能瓶颈,因为它们将整个工作簿加载到内存中。为了解决这个问题,POI提供了SXSSF(Streaming Usermodel API)和XSSFEventUserModel API。这里的主题是利用...
在本文中,我们将重点关注如何使用POI 3.5版本中的HSSF和XSSF库来读写Excel文件。 HSSF(Horizontally Stored Sheet Format)是POI针对旧版BIFF格式(Excel 97-2007)的API,而XSSF(XML Spreadsheet Format)则是...
在Java环境中,Apache POI 提供了一套API,使得开发者能够创建、修改和读取Excel文件。这个压缩包包含了Apache POI库的多个版本及其依赖库,如ooxml-schemas、xmlbeans等,用于支持对Excel文件的OOXML(Office Open ...
- **读取Excel**:使用Apache POI,开发者可以打开Excel文件,访问工作簿、工作表,以及单元格中的数据。例如,通过`WorkbookFactory.create()`方法加载文件,然后遍历工作表和单元格进行数据提取。 - **写入Excel...
标题中的“poi xssf读取excel2007”指的是使用Apache POI库来读取Microsoft Excel 2007及以上版本(XLSX格式)的文件。Apache POI是Java社区开发的一个开源项目,它提供了API来处理Microsoft Office格式的文件,包括...
Apache POI提供了HSSF(Horrible Spreadsheet Format)和XSSF(XML Spreadsheet Format)两个主要组件,分别用于读写旧版的.BIFF8格式(Excel 97-2007)和OOXML(Office Open XML)格式的Excel文件。 在HSSF中,...
1. **读取Microsoft Office文件**:通过HSSF(Horrible Spreadsheet Format)和XSSF(XML Spreadsheet Format)API,Apache POI能够读取旧版的Excel文件(.xls)和新版本的Excel文件(.xlsx)。类似地,HWPF...
这篇博文主要讲解如何使用Apache POI库来读取Excel文件的内容,无论是2003版的.XLS还是2007版及以后的.XLSX格式。 在Java编程中,Apache POI 提供了丰富的API,使得开发者可以方便地操作Excel文件。首先,我们需要...
2. **poi-5.2.3.jar**: 这是Apache POI的核心库,包含了处理HSSF(Excel的低级API,用于老版本的.xls文件)和XSSF(Excel的高级API,用于.xlsx文件)所需的所有类和方法。 3. **poi-ooxml-5.2.3.jar**: 这个库用于...