Apache POI HSSF和XSSF讀寫EXCEL總結


HSSF是指2007年以前的,XSSF是指2007年版本以上的

這個還是比較好用的,這些總結來自Apache的官方向導的點點滴滴

詳細的請參考http://poi.apache.org/spreadsheet/quick-guide.html

1.導出excel:

package test.worksheet;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.util.Date;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.hssf.util.HSSFColor;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.CellStyle;
import org.apache.poi.ss.usermodel.CreationHelper;
import org.apache.poi.ss.usermodel.Font;
import org.apache.poi.ss.usermodel.IndexedColors;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;

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, "YYYY-MM-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();  
    }

    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;
    }

    public static CellStyle setCellStyleAlignment(CellStyle cellStyle,short halign,short valign){
       //設置上下
       cellStyle.setAlignment(halign);
       //設置左右
       cellStyle.setVerticalAlignment(valign);
       return cellStyle;
    }

    public static CellStyle setCellFormat(CreationHelper helper,CellStyle cellStyle,String fmt){
       //還可以用其它方法創建format
       cellStyle.setDataFormat(helper.createDataFormat().getFormat(fmt));
       return cellStyle;
    }

    public static CellStyle setFillBackgroundColors(CellStyle cellStyle,short bg,short fg,short fp){
       cellStyle.setFillBackgroundColor(bg);
       cellStyle.setFillForegroundColor(fg);
       cellStyle.setFillPattern(fp);
       return cellStyle;
    }

    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;
    }
    }

2.導入excel:

package test.worksheet;


import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.DateUtil;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.ss.usermodel.WorkbookFactory;

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("");
       }
    }
    }

3.需要的包

poi-3.9-20121203.jar和poi-ooxml-3.7-20121029.jar

文章來源:http://blog.sina.com.cn/s/blog_717c2b0f0100wcef.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM