利用poi生成excel表格

import java.io.FileOutputStream;
import java.util.List;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFFont;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.hssf.util.Region;

public class ExportToExcel {

 /**
  * @description
  *
  * @param args
  */
 public static void main(String[] args)
 {
  List listRow = null;
  List listCell = null;
  // TODO Auto-generated method stub
  ExportToExcel(listRow,listCell);
 }
 public static void ExportToExcel(List listRow,List listCell)
 {
    try
    {
       HSSFWorkbook wb = new HSSFWorkbook();
       HSSFSheet sheet = wb.createSheet("sheet1");
       HSSFRow row = null;
       HSSFCell cell = null;
      
       //width size
//        sheet.setDefaultColumnWidth((short)500);
      
       //style
       HSSFCellStyle cs = wb.createCellStyle();//create astyle
       HSSFFont littleFont = wb.createFont();//create a Font
       littleFont.setFontName("SimSun");
       littleFont.setFontHeightInPoints((short)7);
       cs.setFont(littleFont);//set font
       cs.setAlignment(HSSFCellStyle.ALIGN_CENTER);//align center
       cs.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);//valign middle
       cs.setBorderBottom(HSSFCellStyle.BORDER_THIN);//bottom border
       cs.setBorderLeft(HSSFCellStyle.BORDER_THIN);//left border
       cs.setBorderRight(HSSFCellStyle.BORDER_THIN);//right border
       cs.setBorderTop(HSSFCellStyle.BORDER_THIN);//top border
            
       //file name
       /*
       row = sheet.createRow((short)0);
       row.setHeight((short)300);
       cell = row.createCell((short)0);
       cell.setEncoding(HSSFCell.ENCODING_UTF_16);
       cell.setCellValue("This is a test out print");
       sheet.addMergedRegion(new Region(0,(short)0,0,(short)7));//merged region
      
      
       row = sheet.createRow((short)1);
       row.setHeight((short)300);
       cell = row.createCell((short)0);
       cell.setEncoding(HSSFCell.ENCODING_UTF_16);
       cell.setCellValue("name");
       sheet.addMergedRegion(new Region(1,(short)0,1,(short)1));
      
       cell = row.createCell((short)2);
       cell.setEncoding(HSSFCell.ENCODING_UTF_16);
       cell.setCellValue("sex");
       sheet.addMergedRegion(new Region(1,(short)2,1,(short)3));
      
       cell = row.createCell((short)4);
       cell.setEncoding(HSSFCell.ENCODING_UTF_16);
       cell.setCellValue("nation");
       sheet.addMergedRegion(new Region(1,(short)4,1,(short)5));
      
       cell = row.createCell((short)6);
       cell.setEncoding(HSSFCell.ENCODING_UTF_16);
       cell.setCellValue("native place");
       sheet.addMergedRegion(new Region(1,(short)6,1,(short)7));
      
      
       row = sheet.createRow((short)2);
       row.setHeight((short)300);
       cell = row.createCell((short)0);
       cell.setEncoding(HSSFCell.ENCODING_UTF_16);
       cell.setCellValue("aaa");
       sheet.addMergedRegion(new Region(2,(short)0,2,(short)1));
      
      
       cell = row.createCell((short)2);
       cell.setEncoding(HSSFCell.ENCODING_UTF_16);
       cell.setCellValue("male");
       sheet.addMergedRegion(new Region(2,(short)2,2,(short)3));
      
       cell = row.createCell((short)4);
       cell.setEncoding(HSSFCell.ENCODING_UTF_16);
       cell.setCellValue("han");
       sheet.addMergedRegion(new Region(2,(short)4,2,(short)5));
      
       cell = row.createCell((short)6);
       cell.setEncoding(HSSFCell.ENCODING_UTF_16);
       cell.setCellValue("chengduaa");
       sheet.addMergedRegion(new Region(2,(short)6,2,(short)7));
      
       row = sheet.createRow((short)3);
       row.setHeight((short)300);
       cell = row.createCell((short)0);
       cell.setEncoding(HSSFCell.ENCODING_UTF_16);
       cell.setCellValue("bbb");
       sheet.addMergedRegion(new Region(3,(short)0,3,(short)1));
      
       cell = row.createCell((short)2);
       cell.setEncoding(HSSFCell.ENCODING_UTF_16);
       cell.setCellValue("man");
       sheet.addMergedRegion(new Region(3,(short)2,3,(short)3));
      
       cell = row.createCell((short)4);
       cell.setEncoding(HSSFCell.ENCODING_UTF_16);
       cell.setCellValue("han");
       sheet.addMergedRegion(new Region(3,(short)4,3,(short)5));
      
       cell = row.createCell((short)6);
       cell.setEncoding(HSSFCell.ENCODING_UTF_16);
       cell.setCellValue("chengduaa");
       sheet.addMergedRegion(new Region(3,(short)6,3,(short)7));
       */
      
       for(short i=0; i <listRow.size()+1;i++)

 {
    row = sheet.createRow(i);
    row.setHeight((short)300);
       for(short j=0; j<listCell.size();j++)        

      {

      cell = row.createCell(j);
        if(i==0)
        {
         cell.setCellValue(listCell.get(j).toString());
        }
        else if(i<=listRow.size())
        { 
         cell.setCellValue(((List)listRow.get(i-1)).get(j).toString());
        }
        cell.setEncoding(HSSFCell.ENCODING_UTF_16);
       }
     }
      
       //println
       FileOutputStream fileOut = new FileOutputStream("C:\\Documents and Settings\\wei\\Desktop\\ReprotByArtist20070226.xls");
       wb.write(fileOut);
       fileOut.close();
       System.out.println("Export successfully...");
   }
    catch (Exception e)
    {
       e.printStackTrace();
    }
 }
}

你可能感兴趣的:(DAO,apache,Excel,J#)