POI操作EXCEL
[*]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){//还可以用其它方法创建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文件
<div class="dp-highlighter"><div class="bar"><div class="tools">Java代码 http://www.iteye.com/images/icon_copy.gif
页:
[1]