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