• 学会简单使用poi进行excel有关操作


    直接上代码:

    官网上的抄的api例子:

    package com.test;
    
    import java.io.File;
    import java.io.FileInputStream;
    import java.io.FileNotFoundException;
    import java.io.FileOutputStream;
    import java.io.IOException;
    import java.io.InputStream;
    import java.util.Calendar;
    import java.util.Date;
    
    import org.apache.poi.EncryptedDocumentException;
    import org.apache.poi.hssf.extractor.ExcelExtractor;
    import org.apache.poi.hssf.usermodel.HSSFWorkbook;
    import org.apache.poi.hssf.usermodel.HeaderFooter;
    import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
    import org.apache.poi.openxml4j.opc.OPCPackage;
    import org.apache.poi.poifs.filesystem.NPOIFSFileSystem;
    import org.apache.poi.poifs.filesystem.POIFSFileSystem;
    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.DataFormat;
    import org.apache.poi.ss.usermodel.DateUtil;
    import org.apache.poi.ss.usermodel.Font;
    import org.apache.poi.ss.usermodel.Footer;
    import org.apache.poi.ss.usermodel.IndexedColors;
    import org.apache.poi.ss.usermodel.PrintSetup;
    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;
    import org.apache.poi.ss.util.CellRangeAddress;
    import org.apache.poi.ss.util.CellReference;
    import org.apache.poi.ss.util.CellUtil;
    import org.apache.poi.ss.util.RegionUtil;
    import org.apache.poi.ss.util.WorkbookUtil;
    import org.apache.poi.xssf.usermodel.XSSFCell;
    import org.apache.poi.xssf.usermodel.XSSFCellStyle;
    import org.apache.poi.xssf.usermodel.XSSFColor;
    import org.apache.poi.xssf.usermodel.XSSFRow;
    import org.apache.poi.xssf.usermodel.XSSFSheet;
    import org.apache.poi.xssf.usermodel.XSSFWorkbook;
    import org.junit.Test;
    
    /**
     * 根据api一些简单操作
     * @author Administrator
     *
     */
    public class CreateExcel {
        String str="C:\Users\Administrator.PMIMP83HWNIKWOV\Desktop\poi\create workbook";
        public static void main(String[] args) {
            CreateExcel ce=new CreateExcel();
    //        String str="C:\Users\Administrator.PMIMP83HWNIKWOV\Desktop\poi\create workbook";
    //        ce.createSheet(new HSSFWorkbook(), str+"\demo0.xls");
    //        ce.createCell();
            ce.createDateCell();
        }
        
        /**
         * 创建Workbook
         */
        public void createWorkbook(){
            
            Workbook wb=null;
            FileOutputStream fileOut=null;
            try {
                wb=new HSSFWorkbook();
                fileOut=new FileOutputStream(str+"\demo.xls");
                wb.write(fileOut);
                fileOut.close();
                
                wb=new XSSFWorkbook();
                fileOut=new FileOutputStream(str+"\demo1.xlsx");
                wb.write(fileOut);
                fileOut.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        
        //建表,不要问我为什么注释有些是英文的,官网上扣下来的
        public void createSheet(Workbook wb,String filename){
            Sheet sheet1=wb.createSheet("sheet1");
            // Note that sheet name is Excel must not exceed 31 characters
            // and must not contain any of the any of the following characters:
            // 0x0000
            // 0x0003
            // colon (:)
            // backslash ()
            // asterisk (*)
            // question mark (?)
            // forward slash (/)
            // opening square bracket ([)
            // closing square bracket (])
    
            // You can use org.apache.poi.ss.util.WorkbookUtil#createSafeSheetName(String nameProposal)}
            // for a safe way to create valid names, this utility replaces invalid characters with a space (' ')
            
            String safeName=WorkbookUtil.createSafeSheetName("[O'Briend's sales*?]");//这个方法会去除名称字符串中的不合法字符
            Sheet sheet3=wb.createSheet(safeName);
            try {
                FileOutputStream fileOut=new FileOutputStream(filename, true);
                wb.write(fileOut);
                fileOut.close();
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        
        /**
         * 创建细胞,也就是创建格子
         */
        public void createCell(){
            Workbook wb=new HSSFWorkbook();//xsl
            //Workbook wb=new XSSFWorkbook();
            CreationHelper createHelper=wb.getCreationHelper();
            Sheet sheet=wb.createSheet("sheet3");
            
            //create a row and put some cells in it.Rows are 0 based
            Row row=sheet.createRow((short)0);
            //create a cell and put a value in it
            Cell cell=row.createCell(0);//不填写类型的话,默认的类型是this.createCell(column,HSSFCell.CELL_TYPE_BLANK);
            cell.setCellValue(1);
            
            //or do it on one line
            row.createCell(1).setCellValue(1.2);//创建和赋值连成一行
            row.createCell(2).setCellValue(createHelper.createRichTextString("This is a string"));
            row.createCell(3).setCellValue(true);
            row.createCell(4).setCellValue("nihao");
            
            //write the output to a file
            try {
                
                FileOutputStream fileOut=new FileOutputStream("C:\Users\Administrator.PMIMP83HWNIKWOV\Desktop\poi\create workbook\demo.xls",true);
                wb.write(fileOut);
                fileOut.close();
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        
        //创建日期类型cell
        public void createDateCell(){
            Workbook wb=new HSSFWorkbook();
            //Workbook wb=new XSSFWorkbook();
            CreationHelper createHelper=wb.getCreationHelper();
            Sheet sheet=wb.createSheet("new sheet");
            
            Row row=sheet.createRow(0);
            //create a row and put a date value in it.The first cell is not styled as a date.
            Cell cell=row.createCell(0);
            cell.setCellValue(new Date());
            
            //we style the second cell as a date (and time).It is important to create a new 
            //cell style from the workbook oterwise you can end up modifying the builting in style and effecting not only this cell but other cells
            //设置日期的格式是分厂重要的
            CellStyle cellStyle=wb.createCellStyle();
            cellStyle.setDataFormat(
                    createHelper.createDataFormat().getFormat("m/d/yy h:mm")
            )    ;
            cell=row.createCell(1);
            cell.setCellValue(new Date());
            cell.setCellStyle(cellStyle);
            
            //write the output to a file
            FileOutputStream fileOut;
            try {
                
                fileOut = new FileOutputStream(str+"\demo4.xls");
                wb.write(fileOut);
                fileOut.close();
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
            
        }
        
        //使用不同类型的cell
        @Test
        public void useOtherTypeCell(){
            Workbook wb=new HSSFWorkbook();
            Sheet sheet=wb.createSheet("new sheet");
            Row row=sheet.createRow((short)2);
            row.createCell(0).setCellValue(1.1);
            row.createCell(1).setCellValue(new Date());
            row.createCell(2).setCellValue(Calendar.getInstance());
            row.createCell(3).setCellValue("a string");
            row.createCell(4).setCellValue(true);
            row.createCell(5).setCellType(Cell.CELL_TYPE_ERROR);
            
            //write the output to a file
            FileOutputStream fileOut;
            try {
                
                fileOut = new FileOutputStream(str+"\demo5.xls");
                wb.write(fileOut);
                fileOut.close();
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        
        //文件VS输入流
        @Test
        public void FileVSStream(){
            //打开工作薄时,要么.xsl HSSFWorkbook或.xlsx XSSFWorkbook,可以从一个工作薄 文件 或者一个InputStream,使用一个文件对象允许更低的
            //内存消耗,而一个InputStream需要更多的内存缓冲区
            
            //使用WorkbookFactory获取Workbook
            try {
                Workbook wb=WorkbookFactory.create(new File(str+"\MyExcel.xlsx"));
            } catch (EncryptedDocumentException e) {
                e.printStackTrace();
            } catch (InvalidFormatException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
            
            //使用InputStream获取Workbook对象
            try {
                Workbook wb=WorkbookFactory.create(new FileInputStream(str+"\MyExcel.xlsx"));
                
            } catch (EncryptedDocumentException e) {
                e.printStackTrace();
            } catch (InvalidFormatException e) {
                e.printStackTrace();
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
            
            //如果使用HSSFWorkbook或者XSSFWorkbook直接,通常应该使用NPOIFSFileSystem或OPCPackage 有完全控制的生命周期(包括完成后关闭该文件)
            try {
                NPOIFSFileSystem fs=new NPOIFSFileSystem(new File(str+"\MyExcel.xls"));
                HSSFWorkbook wb=new HSSFWorkbook(fs.getRoot(),true);
                //...
                fs.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
            try {
                NPOIFSFileSystem fs=new NPOIFSFileSystem(new FileInputStream(str+"\MyExcel.xls"));
                HSSFWorkbook wb=new HSSFWorkbook(fs.getRoot(),true);
                //...
                fs.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
            //XXSFWorkbook
            try {
                OPCPackage pkg=OPCPackage.open(new File(str+"\MyExcel.xlsx"));
                XSSFWorkbook wb=new XSSFWorkbook(pkg);
                //...
                pkg.close();
            } catch (InvalidFormatException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
            try {
                OPCPackage pkg=OPCPackage.open(new FileInputStream(str+"\MyExcel.xlsx"));
                XSSFWorkbook wb=new XSSFWorkbook(pkg);
                //...
                pkg.close();
            } catch (InvalidFormatException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        
        //演示各种对齐选项
        @Test
        public void alignTest(){
            Workbook wb=new XSSFWorkbook();
            
            Sheet sheet=wb.createSheet();
            Row row=sheet.createRow((short)2);
            row.setHeightInPoints(30);//设置行高
            
            createCell(wb,row,(short)0,CellStyle.ALIGN_CENTER,CellStyle.VERTICAL_BOTTOM);
            createCell(wb,row,(short)1,CellStyle.ALIGN_CENTER_SELECTION,CellStyle.VERTICAL_BOTTOM);
            createCell(wb,row,(short)2,CellStyle.ALIGN_FILL,CellStyle.VERTICAL_CENTER);
            createCell(wb,row,(short)3,CellStyle.ALIGN_GENERAL, CellStyle.VERTICAL_CENTER);
            createCell(wb, row, (short) 4, CellStyle.ALIGN_JUSTIFY, CellStyle.VERTICAL_JUSTIFY);
            createCell(wb, row, (short) 5, CellStyle.ALIGN_LEFT, CellStyle.VERTICAL_TOP);
            createCell(wb, row, (short) 6, CellStyle.ALIGN_RIGHT, CellStyle.VERTICAL_TOP);
            
            //write the output to a file
            FileOutputStream fileOut;
            try {
                fileOut = new FileOutputStream(str+"\xssf-align.xlsx");
                 wb.write(fileOut);
                 fileOut.close();
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
           
        }
        public void createCell(Workbook wb,Row row,short column,short halign,short valign){
            Cell cell=row.createCell(column);
            cell.setCellValue("Align It");
            CellStyle cellStyle=wb.createCellStyle();
            cellStyle.setAlignment(halign);
            cellStyle.setVerticalAlignment(valign);
            cell.setCellStyle(cellStyle);
        }
        
        //使用边界
        @Test
        public void usrBorder(){
            Workbook wb=new HSSFWorkbook();
            Sheet sheet=wb.createSheet("new sheet");
            
            Row row=sheet.createRow(1);
            
            Cell cell=row.createCell(1);
            cell.setCellValue(4);
            
            //style the cell with borders all around
            CellStyle style=wb.createCellStyle();
            style.setBorderBottom(CellStyle.BORDER_THIN);
            style.setBottomBorderColor(IndexedColors.BLACK.getIndex());
            style.setBorderLeft(CellStyle.BORDER_THIN);
            style.setLeftBorderColor(IndexedColors.GREEN.getIndex());
            style.setBorderRight(CellStyle.BORDER_THIN);
            style.setRightBorderColor(IndexedColors.BLUE.getIndex());
            style.setBorderTop(CellStyle.BORDER_MEDIUM_DASHED);
            style.setTopBorderColor(IndexedColors.BLACK.getIndex());
            cell.setCellStyle(style);
            
            FileOutputStream fileOut;
            try {
                fileOut = new FileOutputStream(str+"\demo7.xls");
                 wb.write(fileOut);
                 fileOut.close();
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
    
        }
        
        @Test
        public void IteratorRowAndCell(){
            //有时候,你想遍历workbook,一个表中的所有行或者所有的cell
            /*
             *workbook.sheetIterator(),sheet.rowIterator(),row.cellIterator() ,或者隐式地使用forEach
             *注意使用迭代器等遍历注意间隔和空缝隙
             */
        }
        
        public void IteratorWhiteCell(Sheet sheet){
            int rowStart=Math.min(15,sheet.getFirstRowNum());
            int rowEnd=Math.max(1400, sheet.getLastRowNum());
            
            for(int rowNum=rowStart;rowNum<rowEnd;rowNum++){
                Row r=sheet.getRow(rowNum);
                if(r==null){
                    //这行是空的
                    continue;
                }
                int lastColumn=r.getLastCellNum();
                for(int cn=0;cn<lastColumn;cn++){
                    Cell c=r.getCell(cn, Row.RETURN_BLANK_AS_NULL);
                    if(c==null){
                        //the spreadsheet is empty in this cell
                    }else{
                        //Do something useful with the cell's contents
                    }
                }
            }
        }
        //获取单元格内容
        /*
         *To get the contents of a cell,you first need to know what kind of the cell is(asking a string cell for its numeric will
         *ge you a NumberFormatException for example)
         *
         * 得到单元格内容,你首先需要知道它是什么类型,否则错误的类型可能会出现NumberFormatException
         */
        @Test
        public void getContent(){
            Workbook wb=null;
            try {
                wb = new XSSFWorkbook(new File(str+"\订餐统计.xlsx"));
            } catch (InvalidFormatException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
            Sheet sheet1=wb.getSheetAt(0);
            for(Row row:sheet1){
                for(Cell cell:row){
                    CellReference cellRef=new CellReference(row.getRowNum(),cell.getColumnIndex());
                    System.out.print(cellRef.formatAsString());
                    System.out.println(" - ");
                    
                    switch(cell.getCellType()){
                    case Cell.CELL_TYPE_STRING:
                        System.out.println(cell.getRichStringCellValue().getString());
                        break;
                    case Cell.CELL_TYPE_NUMERIC:
                        if(DateUtil.isCellDateFormatted(cell)){
                            System.out.println(cell.getDateCellValue());
                        }else{
                            System.out.println(cell.getNumericCellValue());
                        }
                        break;
                    case Cell.CELL_TYPE_BOOLEAN:
                        System.out.println(cell.getBooleanCellValue());
                        break;
                    case Cell.CELL_TYPE_FORMULA:
                        System.out.println(cell.getBooleanCellValue());
                        break;
                    default:
                        System.out.println();
                    }
                }
            }
            
        }
        
        //文本提取
        //对于大多数文本提取要求
        @Test
        public void getText(){
            InputStream inp=null;
            HSSFWorkbook wb=null;
            try {
                inp = new FileInputStream(str+"\demo.xls");
                wb=new HSSFWorkbook(new POIFSFileSystem(inp));
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
            
            ExcelExtractor extractor=new ExcelExtractor(wb);
            
            extractor.setFormulasNotResults(true);
            extractor.setIncludeSheetNames(false);
            String text=extractor.getText();
            System.out.println(text);
        }
        
        //填充和颜色
        @Test
        public void paddingAndColor(){
            Workbook wb=new XSSFWorkbook();
            Sheet sheet=wb.createSheet("new sheet");
            
            //create a row and put some cells in it.Row are 0 based
            Row row=sheet.createRow((short)1);
            
            //Aqua background  aqua:浅绿色
            CellStyle style=wb.createCellStyle();
            style.setFillBackgroundColor(IndexedColors.AQUA.getIndex());
            style.setFillPattern(CellStyle.BIG_SPOTS);
            Cell cell=row.createCell((short)1);
            cell.setCellValue("X");
            cell.setCellStyle(style);
            
            //Orange "foreground",foreground beging the fill foreground not the font color . foreground:前景
            style=wb.createCellStyle();
            style.setFillForegroundColor(IndexedColors.ORANGE.getIndex());
            style.setFillPattern(CellStyle.SOLID_FOREGROUND);
            cell=row.createCell((short)2);
            cell.setCellValue("X");
            cell.setCellStyle(style);
            
            //write to output to a file
             FileOutputStream fileOut;
                try {
                    fileOut = new FileOutputStream(str+"\demo8.xlsx");
                     wb.write(fileOut);
                     fileOut.close();
                } catch (FileNotFoundException e) {
                    e.printStackTrace();
                } catch (IOException e) {
                    e.printStackTrace();
                }
        }
        
        //合并单元格
        @Test
        public void combineCell(){
            Workbook wb=new HSSFWorkbook();
            Sheet sheet=wb.createSheet("new sheet");
            
            Row row=sheet.createRow((short)1);
            Cell cell=row.createCell((short)1);
            cell.setCellValue("this is a test of merging");
            
            sheet.addMergedRegion(new CellRangeAddress(
                1, //    firstRow, 全部从0为基数
                1, //    lastRow,
                1,//    firstCol,
                2//    lastCol
                ));
            
            FileOutputStream fileOut;
            try {
                fileOut = new FileOutputStream(str+"\demo9.xls");
                 wb.write(fileOut);
                 fileOut.close();
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        
        //设置字体
        @Test
        public void useFont(){
            Workbook wb=new HSSFWorkbook();
            Sheet sheet=wb.createSheet("new sheet");
            
            Row row=sheet.createRow(1);
            
            //create a new font and alert it
            Font font=wb.createFont();
            font.setFontHeight((short)24);
            font.setFontName("Courier New");
            font.setItalic(true);
            font.setStrikeout(true);
            
            CellStyle style=wb.createCellStyle();
            style.setFont(font);
            Cell cell=row.createCell(1);
            cell.setCellValue("This is a test of fonts");
            cell.setCellStyle(style);
            
            FileOutputStream fileOut;
            try {
                fileOut = new FileOutputStream(str+"\demo10.xls");
                 wb.write(fileOut);
                 fileOut.close();
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
            //Note ,the maximun number of unique fonts in a workbooks is limited 32767,you should reuse fonts in you applications
            //instead of creating a font for each cell
            //在一个workbook中,每一个font是唯一的,好像在32767之内。你应该使用同一个Font然后循环给单元格设置样式而不是在循环中初始化多个font
            
            /*//错误的:
            for(int i=0;i<10000;i++){
                row=sheet.createRow(i);
                cell=row.createCell((short)0);
                
                style=wb.createCellStyle();
                font=wb.createFont();
                font.setBoldweight(Font.BOLDWEIGHT_BOLD);
                style.setFont(font);
                cell.setCellStyle(style);
            }
            //正确的:
            style=wb.createCellStyle();
            font=wb.createFont();
            font.setBoldweight(Font.BOLDWEIGHT_BOLD);
            style.setFont(font);
            for(int i=0;i<10000;i++){
                row=sheet.createRow(i);
                cell=row.createCell((short)0);
                cell.setCellStyle(style);
            }*/
        }
        
        //自定义颜色
        @Test
        public  void customColor(){
    //        //HSSF中
    //        HSSFWorkbook wb=new HSSFWorkbook();
    //        HSSFSheet sheet=wb.createSheet();
    //        HSSFRow row=sheet.createRow((short)0);
    //        @SuppressWarnings("deprecation")
    //        HSSFCell cell=row.createCell((short)0);
    //        cell.setCellValue("Default Palette");
    //        
    //        //apply some colors from the standard palette,as in the previous examples
    //        //we will use red text on a lime background
    //        HSSFCellStyle style=wb.createCellStyle();
    //        style.setFillForegroundColor(HSSFColor.LIME.index);
    //        style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
    //        
    //        HSSFFont font=wb.createFont();
    //        font.setColor(HSSFColor.RED.index);//字体颜色
    //        style.setFont(font);
    //        
    //        cell.setCellStyle(style);
    //        
    //        //save with the default palette
    //        try {
    //            FileOutputStream out=new FileOutputStream(str+"\default_patte.xls");
    //            wb.write(out);
    //            wb.close();
    //        } catch (FileNotFoundException e) {
    //            e.printStackTrace();
    //        } catch (IOException e) {
    //            e.printStackTrace();
    //        }
    //        
    //        //now let's replace RED and LIMIT in the palette with a more attractive combination
    //        //(lovingly borrowed from freebsd.org)
    //        cell.setCellValue("Modified Palette");
    //        
    //        //creating a custom palette for the workbook
    //        HSSFPalette palette=wb.getCustomPalette();
    //        
    //        //replacing the standard red with freebsd.org red
    //        palette.setColorAtIndex(HSSFColor.LIME.index,
    //                (byte) 153,//red,
    //                (byte) 0,//green,
    //                (byte) 0//blue
    //            );
    //        //replacing lime with freebsd.org gold
    //        palette.setColorAtIndex(HSSFColor.LIME.index, (byte)255, (byte)204, (byte)102);
    //        
    //        //save with the modified palette
    //        //note that wherever we have previously used RED or LIME,the new colors magically appear
    //        try {
    //            FileOutputStream out=new FileOutputStream(str+"\modified_palette.xls");
    //            wb.write(out);
    //            out.close();
    //        } catch (FileNotFoundException e) {
    //            e.printStackTrace();
    //        } catch (IOException e) {
    //            e.printStackTrace();
    //        }
    //        
            //在XSSF中
            XSSFWorkbook wb1=new XSSFWorkbook();
            XSSFSheet sheet1=wb1.createSheet();
            XSSFRow row1=sheet1.createRow(0);
            XSSFCell cell1=row1.createCell(0);
            cell1.setCellValue("custom XSSF colors");
            
            XSSFCellStyle style1=wb1.createCellStyle();
            style1.setFillForegroundColor(new XSSFColor(new java.awt.Color(128,0,128)));//设置背景颜色
            style1.setFillPattern(CellStyle.SOLID_FOREGROUND);
            cell1.setCellStyle(style1);
            try {
                FileOutputStream out=new FileOutputStream(str+"\modified_palette1.xlsx");
                wb1.write(out);
                out.close();
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
        } 
        //读和修改
        @Test
        public void readAndRewrite(){
            try {
                InputStream inp=new FileInputStream(str+"\cs.xlsx");
                //InputStream inp=new FileInputStream("workbook.xlsx");
                
                Workbook wb=WorkbookFactory.create(inp);
                Sheet sheet=wb.getSheetAt(0);
                Row row=sheet.getRow(2);
                Cell cell=row.getCell(3);
                if(cell==null){
                    cell=row.createCell(3);
                }
                cell.setCellType(Cell.CELL_TYPE_STRING);
                cell.setCellValue("a test");
                
                FileOutputStream fileOut=new FileOutputStream(str+"\cs.xlsx");
                wb.write(fileOut);
                fileOut.close();
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (EncryptedDocumentException e) {
                e.printStackTrace();
            } catch (InvalidFormatException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        
        //在单元格内使用文本换行
        @Test
        public void useNewLine(){
            Workbook wb=new XSSFWorkbook();//or new HSSFWorkbook();
            Sheet sheet=wb.createSheet();
            
            Row row=sheet.createRow(2);
            Cell cell=row.createCell(2);
            cell.setCellValue("use 
     with word warp on to create a new line");
            
            //to enable newlines you need set a cell styles with warp==true
            CellStyle cs=wb.createCellStyle();
            cs.setWrapText(true);
            cell.setCellStyle(cs);
            
            //increase row height to accomodate two lines of text
            //设置行高为两个行高
            row.setHeightInPoints(2*sheet.getDefaultRowHeightInPoints());
            
            //adjust column width to fit the content
            sheet.autoSizeColumn((short)2);
            
            FileOutputStream fileOut;
            try {
                fileOut = new FileOutputStream(str+"\ooxml-newlines.xlsx");
                wb.write(fileOut);
                fileOut.close();
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
            
        }
        
        //数据格式
        @Test
        public void formatData(){
            Workbook wb=new HSSFWorkbook();
            Sheet sheet=wb.createSheet("format sheet");
            CellStyle style;
            DataFormat format=wb.createDataFormat();
            Row row;
            Cell cell;
            short rowNum=0;
            short colNum=0;
            
            row=sheet.createRow(rowNum++);
            cell=row.createCell(colNum);
            cell.setCellValue(11111.25);
            style=wb.createCellStyle();
            style.setDataFormat(format.getFormat("0.0"));
            cell.setCellStyle(style);
            
            row=sheet.createRow(rowNum++);
            cell=row.createCell(colNum);
            cell.setCellValue(11111.25);
            style=wb.createCellStyle();
            style.setDataFormat(format.getFormat("#,##0.0000"));
            cell.setCellStyle(style);
    
            FileOutputStream fileOut;
            try {
                fileOut = new FileOutputStream(str+"\demo11.xls");
                wb.write(fileOut);
                fileOut.close();
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
            
        }
        //有道翻译感觉不太准确
        //Fix Sheet to One Page
        @Test
        public void fixToOnePage(){
            Workbook wb=new HSSFWorkbook();
            Sheet sheet=wb.createSheet("format sheet");
            PrintSetup ps=sheet.getPrintSetup();
            
            sheet.setAutobreaks(true);
            
            ps.setFitHeight((short)1);
            ps.setFitWidth((short)1);
            
            //create various cells and rows for spreadsheet
            Row row=sheet.createRow(1);
            Cell cell=row.createCell(0);
            cell.setCellValue("nihao");
            FileOutputStream fileOut;
            try {
                fileOut = new FileOutputStream(str+"\demo12.xls");
                wb.write(fileOut);
                fileOut.close();
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        //Set Print Area 设置打印区域
        @Test
        public void setPrintArea(){//其实我感觉不出什么东西来,不过api上有就写一下
            Workbook wb=new HSSFWorkbook();
            Sheet sheet=wb.createSheet("sheet1");
            //sets the print area for the first sheet
            wb.setPrintArea(0, "$A$1:$C$2");
            
            //Alternatibely
            wb.setPrintArea(
                    0,//sheetIndex,
                    0,//startColumn,
                    0,//endColumn,
                    0,//startRow,
                    0//endRow
                );
            FileOutputStream fileOut;
            try {
                fileOut = new FileOutputStream(str+"\demo13.xls");
                wb.write(fileOut);
                fileOut.close();
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        
        //Set Page Numbers on Footer
        @Test
        public void setFooter(){
            Workbook wb=new HSSFWorkbook();//or new XSSFWorkbook();
            Sheet sheet=wb.createSheet("format sheet");
            Footer footer=sheet.getFooter();
            footer.setRight("Page "+HeaderFooter.page()+" of "+HeaderFooter.numPages());
            
            //Create various cells and rows for spreadsheet
            Row row=sheet.createRow(1);
            Cell cell=row.createCell(0);
            cell.setCellValue("haha");
            FileOutputStream fileOut;
            try {
                fileOut = new FileOutputStream(str+"\demo14.xls");
                wb.write(fileOut);
                fileOut.close();
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
            
        }
        
        //使用一些函数
        @Test
        public void useSomeFunction(){
            Workbook wb=new HSSFWorkbook();//new XSSFWorkbook();
            Sheet sheet1=wb.createSheet("new sheet");
            
            //create a merged region 合并区域
            Row row=sheet1.createRow(1);
            Row row2=sheet1.createRow(2);
            Cell cell=row.createCell(1);
            cell.setCellValue("This is a test of merging");
            CellRangeAddress region=CellRangeAddress.valueOf("B2:E5");
            sheet1.addMergedRegion(region);
            
            //Set the border and border colors
            final short borderMediumDashed=CellStyle.BORDER_MEDIUM_DASHED;
            RegionUtil.setBorderTop(borderMediumDashed, region, sheet1, wb);
            RegionUtil.setBorderLeft(borderMediumDashed, region, sheet1, wb);
            RegionUtil.setBorderBottom(borderMediumDashed, region, sheet1, wb);
            RegionUtil.setRightBorderColor(borderMediumDashed, region, sheet1, wb);
            RegionUtil.setBottomBorderColor(IndexedColors.AQUA.getIndex(), region, sheet1, wb);
            RegionUtil.setTopBorderColor(IndexedColors.AQUA.getIndex(), region, sheet1, wb);
            RegionUtil.setRightBorderColor(IndexedColors.AQUA.getIndex(), region, sheet1, wb);
            RegionUtil.setLeftBorderColor(IndexedColors.AQUA.getIndex(), region, sheet1, wb);
            
            //shows some usages of HSSFCellUtil
            CellStyle style=wb.createCellStyle();
            style.setIndention((short)4);
            CellUtil.createCell(row, 8, "this is the value of the cell",style);
            Cell cell2=CellUtil.createCell(row2, 8, "this is the value of the cell");
            CellUtil.setAlignment(cell2,wb,CellStyle.ALIGN_CENTER);
            
            //Write out the workbook
            FileOutputStream fileOut;
            try {
                fileOut = new FileOutputStream(str+"\demo15.xls");
                wb.write(fileOut);
                fileOut.close();
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
            
        }
        //重复的行和列
        @Test
        public void repeatingRowAndCol(){
            Workbook wb=new HSSFWorkbook();
            Sheet sheet1=wb.createSheet("Sheet1");
            Sheet sheet2=wb.createSheet("Sheet2");
            
            //set the rows to repeat from 4 to 5 on the first sheet
            sheet1.setRepeatingRows(CellRangeAddress.valueOf("4:5"));
            //set the columns to repeat from column A to C on the secend sheet
            sheet2.setRepeatingColumns(CellRangeAddress.valueOf("A:C"));
            
            FileOutputStream fileOut;
            try {
                fileOut = new FileOutputStream(str+"\demo16.xls");
                wb.write(fileOut);
                fileOut.close();
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        
        
        
    }
    View Code

    简单解析excel:

    package com.test;
    
    import java.io.File;
    import java.io.IOException;
    
    import org.apache.poi.EncryptedDocumentException;
    import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
    import org.apache.poi.ss.usermodel.Cell;
    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;
    /*
      static int     CELL_TYPE_BLANK
              Blank Cell type (3)
    static int     CELL_TYPE_BOOLEAN
              Boolean Cell type (4)
    static int     CELL_TYPE_ERROR
              Error Cell type (5)
    static int     CELL_TYPE_FORMULA
              Formula Cell type (2)
    static int     CELL_TYPE_NUMERIC
              Numeric Cell type (0)
    static int     CELL_TYPE_STRING
              String Cell type (1)
     */
    public class ParseexcelDemo {
        public static void main(String[] args) {
            ParseexcelDemo pxd=new ParseexcelDemo();
            pxd.parseXml("C:\Users\Administrator.PMIMP83HWNIKWOV\Desktop\poi\create workbook\学员烧烤通讯录表.xlsx");
        }
        public void parseXml(String filename){
            Workbook wb=null;
            try {
                wb=WorkbookFactory.create(new File(filename));
                Sheet sheet=wb.getSheetAt(0);
                
                for(Row row:sheet){
                    
                    for(Cell cell:row){
                        System.out.print(getCellValue(cell)+"---");
                    }
                    System.out.println();
                }
            } catch (EncryptedDocumentException e) {
                e.printStackTrace();
            } catch (InvalidFormatException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        
        public Object getCellValue(Cell cell){
            int type=cell.getCellType();
            String show=null;
            switch(type){
            case Cell.CELL_TYPE_BLANK:
                show=null;break;
            case Cell.CELL_TYPE_BOOLEAN:
                show= String.valueOf(cell.getBooleanCellValue());break;
            case Cell.CELL_TYPE_ERROR:
                show=String.valueOf(cell.getErrorCellValue());break;
            case Cell.CELL_TYPE_FORMULA:
                show=cell.getCellFormula();break;
            case Cell.CELL_TYPE_NUMERIC:
                show=String.valueOf(cell.getNumericCellValue());break;
            case Cell.CELL_TYPE_STRING:
                show=cell.getStringCellValue();break;
            default:
                show=null;
            }
            return show;
        }
    }
    View Code

    简单创建excel:

    package com.listenerVedio;
    
    import java.io.FileNotFoundException;
    import java.io.FileOutputStream;
    import java.io.IOException;
    
    import org.apache.poi.hssf.usermodel.HSSFWorkbook;
    import org.apache.poi.ss.usermodel.Cell;
    import org.apache.poi.ss.usermodel.CellStyle;
    import org.apache.poi.ss.usermodel.Row;
    import org.apache.poi.ss.usermodel.Sheet;
    import org.apache.poi.ss.usermodel.Workbook;
    import org.junit.Test;
    
    public class PotTest1 {
        @Test
        public void TestWrite01(){
            Workbook wb=new HSSFWorkbook();
            FileOutputStream fos=null;
            try {
                fos=new FileOutputStream("d:/test/poi/w1.xls");
                Sheet sheet=wb.createSheet("测试01");
                Row row=sheet.createRow(0);
                row.setHeightInPoints(30);//设置行高
                CellStyle cs=wb.createCellStyle();//新建单元格样式对象
                //我们可以使用CellStyle设置单元格的一些关于美化方向的属性,比如颜色,边框,背景等
                cs.setAlignment(CellStyle.ALIGN_CENTER);//设置水平居中
                cs.setVerticalAlignment(CellStyle.VERTICAL_CENTER);//设置垂直居中
                /*
                cs.setBorderBottom((short)1);//设置边框样式 这里发现边框设置样式失败。原来设置边框中使用的是样式的常量
                cs.setBorderTop((short)1);
                cs.setBorderLeft((short)1);
                cs.setBorderRight((short)1);
                */
                cs.setBorderBottom(CellStyle.BORDER_DASH_DOT);
                cs.setBorderLeft(CellStyle.BORDER_MEDIUM_DASH_DOT_DOT);
                Cell c=row.createCell(0);
                c.setCellStyle(cs);//给单元格设置样式
                c.setCellValue("标识");
                c=row.createCell(1);
                c.setCellStyle(cs);
                c.setCellValue("用户名");
                wb.write(fos);
                wb.close();
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
            
            /**
             * 发现这样写是不现实的,因为设置一个单元格样式太过麻烦。虽然使用for、循环可以达到效果
             * 我 们习惯于创建一个模板,模板里面将样式定好,然后我们填充模板里面的元素,然后用来完成数据的导出
             * 能够根据excel转换成对象,能够将对象导成excel,能够带模板的方式导出excel。终极目标
             *
             * 一些思路:如何将对象导出成excel,首先需要有对象,对象一般不是你的实体类而是专门用来导出的自定义对象,应为导出对象的列应该不是所有的
             * 如何确定顶部的标题:使用注解实现。创建Annotation,在其中说明这是excel的resource,顺序也是使用注解实现
             * 
             */
        }
    }
    View Code

    使用模板简单创建excel:

    package com.util;
    
    import java.io.File;
    import java.io.FileNotFoundException;
    import java.io.FileOutputStream;
    import java.io.IOException;
    import java.io.OutputStream;
    import java.util.Calendar;
    import java.util.Date;
    import java.util.HashMap;
    import java.util.Map;
    
    import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
    import org.apache.poi.ss.usermodel.Cell;
    import org.apache.poi.ss.usermodel.CellStyle;
    import org.apache.poi.ss.usermodel.RichTextString;
    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;
    
    /**
     * Excel模板
     * @author Administrator
     *
     */
    public class ExcelTemplate {
        private static ExcelTemplate et=new ExcelTemplate();
        public final static String DATA_LINE="datas";
        public final static String DEFAULT_STYLE="defaultStyle";
        public final static String OWNSTYLE="style";
        private Workbook wb;
        private Sheet sheet;
        /**
         * 数据的初始化列
         */
        private int initColIndex;
        /**
         * 数据的初始化行
         */
        private int initRowIndex;
        /**
         * 数据的当前列
         */
        private int curColIndex;
        /**
         * 数据的当前行
         */
        private int curRowIndex;
        /**
         * 数据的最后一行
         */
        private int lastRowIndex;
        /**
         * 当前行对象
         */
        private Row curRow;
        /**
         * 默认样式
         */
        private CellStyle defaultStyle;
        /**
         * 自定义的样式的集合
         */
        private Map<Integer,CellStyle> styles;
        /**
         * 数据列行高
         */
        private float dataLineHeight;
        /**
         * 单例获取et
         * @return
         */
        public static ExcelTemplate getInstance(){
            return et;
        }
        /**
         * 根据classPath读取模板
         * @param classPath
         * @return
         */
        public ExcelTemplate readTemplateByClasspath(String classPath){
            try {
                wb=WorkbookFactory.create(ExcelTemplate.class.getResourceAsStream(classPath));
            } catch (InvalidFormatException e) {
                e.printStackTrace();
                throw new RuntimeException("取读模板格式有误!请检查");
            } catch (IOException e) {
                e.printStackTrace();
                throw new RuntimeException("取读的模板不存在!请检查");
            }
            initTemp();
            return et;
        }
        /**
         * 根据filePath读取模板
         * @param filePath
         * @return
         */
        public ExcelTemplate  readTemplateByFilepath(String filePath){
            try {
                wb=WorkbookFactory.create(new File(filePath));
            }catch (InvalidFormatException e) {
                e.printStackTrace();
                throw new RuntimeException("取读模板格式有误!请检查");
            } catch (IOException e) {
                e.printStackTrace();
                throw new RuntimeException("取读的模板不存在!请检查");
            }
            initTemp();
            return et;
        }
        /**
         * 将Workbook写入文件
         * @param filePath
         */
        public void writeToFile(String filePath){
            FileOutputStream fos=null;
            try {
                fos=new FileOutputStream(filePath);
                wb.write(fos);
            } catch (FileNotFoundException e) {
                e.printStackTrace();
                throw new RuntimeException("写入的文件不存在!"+e.getMessage());
            } catch (IOException e) {
                e.printStackTrace();
                throw new RuntimeException("写入数据失败!"+e.getMessage());
            }finally{
                try {
                    if(fos!=null){
                        fos.close();
                    }
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
        /**
         * 将Workbook写入输出流
         * @param os
         */
        public void writeToStream(OutputStream os){
            try {
                wb.write(os);
            } catch (IOException e) {
                e.printStackTrace();
                throw new RuntimeException("写入流失败!"+e.getMessage());
            }
        }
        /**
         * 初始化模板
         */
        public void initTemp(){
            sheet=wb.getSheetAt(0);
            initConfigData();
            curRow=sheet.getRow(initRowIndex);
        }
        /**
         * 获取初始化配置数据
         */
        private void initConfigData() {
            lastRowIndex=sheet.getLastRowNum();
            styles=new HashMap<Integer,CellStyle>();
            int styleinRow=0;
            for(Row row:sheet){
                for(Cell cell:row){
                    if(cell.getCellType()!=Cell.CELL_TYPE_STRING) continue;
                    String str=cell.getStringCellValue().trim();
                    if(str.equals(DATA_LINE)){
                        curColIndex=initColIndex=cell.getColumnIndex();
                        curRowIndex=initRowIndex=cell.getRowIndex();
                        dataLineHeight=row.getHeightInPoints();
                    }
                    if(str.equals(DEFAULT_STYLE)){
                        defaultStyle=cell.getCellStyle();
                        styleinRow=cell.getRowIndex();
                    }
                    if(str.equals(OWNSTYLE)){
                        styles.put(cell.getColumnIndex(), cell.getCellStyle());
                        styleinRow=cell.getRowIndex();
                    }
                    
                    /**
                     * 后面可以附加好多其他东西
                     */
                    
                }
            }
            //sheet.removeRow(sheet.getRow(styleinRow));//这里将设置样式的一行删除,样式已经完成了
            /*直接删除不能实现下面的行自动往上顶,使用移动下面的行将前面的行覆盖实现*/
            sheet.shiftRows(styleinRow+1,lastRowIndex--, -1, true, true);
        }
        /**
         * 创建新行
         */
        public void createNewRow(){
            moveData();
            curRow=sheet.createRow(++curRowIndex);
            curRow.setHeightInPoints(dataLineHeight);
            curColIndex=initColIndex;
        }
        /**
         * 创建新列并为新列赋值
         * @param value
         */
        public void createCell(String value){
            Cell c=curRow.createCell(curColIndex);
            if(styles.containsKey(curColIndex))
                c.setCellStyle(styles.get(curColIndex));
            else
                c.setCellStyle(defaultStyle);
            c.setCellValue(value);
            curColIndex++;
        }
        public void createCell(int value){
            Cell c=curRow.createCell(curColIndex);
            if(styles.containsKey(curColIndex))
                c.setCellStyle(styles.get(curColIndex));
            else
                c.setCellStyle(defaultStyle);
            c.setCellValue(value);
            curColIndex++;
        }
        public void createCell(double value){
            Cell c=curRow.createCell(curColIndex);
            if(styles.containsKey(curColIndex))
                c.setCellStyle(styles.get(curColIndex));
            else
                c.setCellStyle(defaultStyle);
            c.setCellValue(value);
            curColIndex++;
        }
        public void createCell(boolean value){
            Cell c=curRow.createCell(curColIndex);
            if(styles.containsKey(curColIndex))
                c.setCellStyle(styles.get(curColIndex));
            else
                c.setCellStyle(defaultStyle);
            c.setCellValue(value);
            curColIndex++;
        }
        public void createCell(Date value){
            Cell c=curRow.createCell(curColIndex);
            if(styles.containsKey(curColIndex))
                c.setCellStyle(styles.get(curColIndex));
            else
                c.setCellStyle(defaultStyle);
            c.setCellValue(value);
            curColIndex++;
        }
        public void createCell(Calendar value){
            Cell c=curRow.createCell(curColIndex);
            if(styles.containsKey(curColIndex))
                c.setCellStyle(styles.get(curColIndex));
            else
                c.setCellStyle(defaultStyle);
            c.setCellValue(value);
            curColIndex++;
        }
        public void createCell(RichTextString value){
            Cell c=curRow.createCell(curColIndex);
            if(styles.containsKey(curColIndex))
                c.setCellStyle(styles.get(curColIndex));
            else
                c.setCellStyle(defaultStyle);
            c.setCellValue(value);
            curColIndex++;
        }
        
        /**
         * 将excel尾部描述列往后移动
         */
        private void moveData(){
            sheet.shiftRows(curRowIndex+1, lastRowIndex++, 1,true, true);    
        }
        /**
         * 设置序号 可选
         */
        public void insertSerial(){
            int serialRow=-1;
            int serialCol=-1;
            boolean findSerial=false;
            for(Row row:sheet){
                if(findSerial) break;
                for(Cell cell:row){
                    if(cell.getCellType()!=Cell.CELL_TYPE_STRING) continue;
                    String str=cell.getStringCellValue().trim();
                    if(str.equals("serial")){
                        serialRow=cell.getRowIndex();
                        serialCol=cell.getColumnIndex();
                        findSerial=true;
                        break;
                    }
                }
            }
            if(serialRow==-1 || serialCol==-1){
                return;
            }
            int count=curRowIndex-initRowIndex+1;
            for(int i=1;i<=count;i++){
                Cell c=sheet.getRow(serialRow++).createCell(serialCol);
                c.setCellValue(i);
            }
        }
        /**
         * 为一些变量赋值
         * @param datas
         */
        public void replaceVariable(Map<String,String> datas){
            for(Row row:sheet){
                for(Cell cell:row){
                    if(cell.getCellType()!=Cell.CELL_TYPE_STRING) continue;
                    String str=cell.getStringCellValue().trim();
                    if(!str.startsWith("#")) continue;
                    if(datas.containsKey(str.substring(1))){
                        cell.setCellValue(datas.get(str.substring(1)));
                    }
                }
            }
        }
    }
    View Code

    实现excel和对象之间的转换:

    package com.ann;
    
    import java.lang.annotation.ElementType;
    import java.lang.annotation.Retention;
    import java.lang.annotation.RetentionPolicy;
    import java.lang.annotation.Target;
    
    @Retention(RetentionPolicy.RUNTIME)
    @Target({ElementType.FIELD})
    public @interface Column {
        String title();
        int order() default 9999;
    }
    package com.entity;
    
    import com.ann.Column;
    /**
     * 用户类
     * @author Administrator
     *
     */
    public class User{
        @Column(title="编号",order=1)
        private int id;
        @Column(title="姓名",order=2)
        private String name;
        @Column(title="年龄",order=3)
        private int age;
        @Column(title="邮箱",order=4)
        private String email;
    
        public int getId() {
            return id;
        }
    
        public void setId(int id) {
            this.id = id;
        }
    
        public String getName() {
            return name;
        }
    
        public void setName(String name) {
            this.name = name;
        }
    
        public int getAge() {
            return age;
        }
    
        public void setAge(int age) {
            this.age = age;
        }
    
        public String getEmail() {
            return email;
        }
    
        public void setEmail(String email) {
            this.email = email;
        }
    
        public User() {
            super();
        }
    
        public User(int id, String name, int age, String email) {
            super();
            this.id = id;
            this.name = name;
            this.age = age;
            this.email = email;
        }
    
        @Override
        public String toString() {
            return "User [id=" + id + ", name=" + name + ", age=" + age
                    + ", email=" + email + "]";
        }
        
    
        
    
    }
    
    
    package com.util;
    /**
     * 列标题列顺序和对应对象字段组成的自定义对象
     * excel和Object的中间对象
     * @author Administrator
     *
     */
    public class ExcelHeader implements Comparable<ExcelHeader>{
        /**
         * excel的标题名
         */
        private String title;
        /**
         * 每一个标题的顺序
         */
        private int order;
        /**
         * 每一个列对应的字段名
         * @return
         */
        private String fieldName;
        public String getTitle() {
            return title;
        }
        public void setTitle(String title) {
            this.title = title;
        }
        public ExcelHeader(String title, int order,String filedName) {
            super();
            this.title = title;
            this.order = order;
            this.fieldName=filedName;
        }
        public ExcelHeader() {
            super();
            
        }
        
        @Override
        public String toString() {
            return "ExcelHeader [title=" + title + ", order=" + order
                    + ", fieldName=" + fieldName + "]";
        }
        public int getOrder() {
            return order;
        }
        public void setOrder(int order) {
            this.order = order;
        }
        @Override
        public int compareTo(ExcelHeader o) {
            return order>o.order?1:(order==o.order?0:-1);
        }
        public void setFieldName(String fieldName) {
            this.fieldName = fieldName;
        }
        public String getFieldName() {
            return fieldName;
        }
        
    }
    package com.util;
    
    import java.io.File;
    import java.io.FileNotFoundException;
    import java.io.FileOutputStream;
    import java.io.IOException;
    import java.io.OutputStream;
    import java.util.Calendar;
    import java.util.Date;
    import java.util.HashMap;
    import java.util.Map;
    
    import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
    import org.apache.poi.ss.usermodel.Cell;
    import org.apache.poi.ss.usermodel.CellStyle;
    import org.apache.poi.ss.usermodel.RichTextString;
    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;
    
    /**
     * Excel模板
     * @author Administrator
     *
     */
    public class ExcelTemplate {
        private static ExcelTemplate et=new ExcelTemplate();
        public final static String DATA_LINE="datas";
        public final static String DEFAULT_STYLE="defaultStyle";
        public final static String OWNSTYLE="style";
        private Workbook wb;
        private Sheet sheet;
        /**
         * 数据的初始化列
         */
        private int initColIndex;
        /**
         * 数据的初始化行
         */
        private int initRowIndex;
        /**
         * 数据的当前列
         */
        private int curColIndex;
        /**
         * 数据的当前行
         */
        private int curRowIndex;
        /**
         * 数据的最后一行
         */
        private int lastRowIndex;
        /**
         * 当前行对象
         */
        private Row curRow;
        /**
         * 默认样式
         */
        private CellStyle defaultStyle;
        /**
         * 自定义的样式的集合
         */
        private Map<Integer,CellStyle> styles;
        /**
         * 数据列行高
         */
        private float dataLineHeight;
        /**
         * 单例获取et
         * @return
         */
        public static ExcelTemplate getInstance(){
            return et;
        }
        /**
         * 根据classPath读取模板
         * @param classPath
         * @return
         */
        public ExcelTemplate readTemplateByClasspath(String classPath){
            try {
                wb=WorkbookFactory.create(ExcelTemplate.class.getResourceAsStream(classPath));
            } catch (InvalidFormatException e) {
                e.printStackTrace();
                throw new RuntimeException("取读模板格式有误!请检查");
            } catch (IOException e) {
                e.printStackTrace();
                throw new RuntimeException("取读的模板不存在!请检查");
            }
            initTemp();
            return et;
        }
        /**
         * 根据filePath读取模板
         * @param filePath
         * @return
         */
        public ExcelTemplate  readTemplateByFilepath(String filePath){
            try {
                wb=WorkbookFactory.create(new File(filePath));
            }catch (InvalidFormatException e) {
                e.printStackTrace();
                throw new RuntimeException("取读模板格式有误!请检查");
            } catch (IOException e) {
                e.printStackTrace();
                throw new RuntimeException("取读的模板不存在!请检查");
            }
            initTemp();
            return et;
        }
        /**
         * 将Workbook写入文件
         * @param filePath
         */
        public void writeToFile(String filePath){
            FileOutputStream fos=null;
            try {
                fos=new FileOutputStream(filePath);
                wb.write(fos);
            } catch (FileNotFoundException e) {
                e.printStackTrace();
                throw new RuntimeException("写入的文件不存在!"+e.getMessage());
            } catch (IOException e) {
                e.printStackTrace();
                throw new RuntimeException("写入数据失败!"+e.getMessage());
            }finally{
                try {
                    if(fos!=null){
                        fos.close();
                    }
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
        /**
         * 将Workbook写入输出流
         * @param os
         */
        public void writeToStream(OutputStream os){
            try {
                wb.write(os);
            } catch (IOException e) {
                e.printStackTrace();
                throw new RuntimeException("写入流失败!"+e.getMessage());
            }
        }
        /**
         * 初始化模板
         */
        public void initTemp(){
            sheet=wb.getSheetAt(0);
            initConfigData();
            curRow=sheet.getRow(initRowIndex);
        }
        /**
         * 获取初始化配置数据
         */
        private void initConfigData() {
            lastRowIndex=sheet.getLastRowNum();
            styles=new HashMap<Integer,CellStyle>();
            int styleinRow=0;
            for(Row row:sheet){
                for(Cell cell:row){
                    if(cell.getCellType()!=Cell.CELL_TYPE_STRING) continue;
                    String str=cell.getStringCellValue().trim();
                    if(str.equals(DATA_LINE)){
                        curColIndex=initColIndex=cell.getColumnIndex();
                        curRowIndex=initRowIndex=cell.getRowIndex();
                        dataLineHeight=row.getHeightInPoints();
                    }
                    if(str.equals(DEFAULT_STYLE)){
                        defaultStyle=cell.getCellStyle();
                        styleinRow=cell.getRowIndex();
                    }
                    if(str.equals(OWNSTYLE)){
                        styles.put(cell.getColumnIndex(), cell.getCellStyle());
                        styleinRow=cell.getRowIndex();
                    }
                    
                    /**
                     * 后面可以附加好多其他东西
                     */
                    
                }
            }
            //sheet.removeRow(sheet.getRow(styleinRow));//这里将设置样式的一行删除,样式已经完成了
            /*直接删除不能实现下面的行自动往上顶,使用移动下面的行将前面的行覆盖实现*/
            sheet.shiftRows(styleinRow+1,lastRowIndex--, -1, true, true);
        }
        /**
         * 创建新行
         */
        public void createNewRow(){
            moveData();
            curRow=sheet.createRow(++curRowIndex);
            curRow.setHeightInPoints(dataLineHeight);
            curColIndex=initColIndex;
        }
        /**
         * 创建新列并为新列赋值
         * @param value
         */
        public void createCell(String value){
            Cell c=curRow.createCell(curColIndex);
            if(styles.containsKey(curColIndex))
                c.setCellStyle(styles.get(curColIndex));
            else
                c.setCellStyle(defaultStyle);
            c.setCellValue(value);
            curColIndex++;
        }
        public void createCell(int value){
            Cell c=curRow.createCell(curColIndex);
            if(styles.containsKey(curColIndex))
                c.setCellStyle(styles.get(curColIndex));
            else
                c.setCellStyle(defaultStyle);
            c.setCellValue(value);
            curColIndex++;
        }
        public void createCell(double value){
            Cell c=curRow.createCell(curColIndex);
            if(styles.containsKey(curColIndex))
                c.setCellStyle(styles.get(curColIndex));
            else
                c.setCellStyle(defaultStyle);
            c.setCellValue(value);
            curColIndex++;
        }
        public void createCell(boolean value){
            Cell c=curRow.createCell(curColIndex);
            if(styles.containsKey(curColIndex))
                c.setCellStyle(styles.get(curColIndex));
            else
                c.setCellStyle(defaultStyle);
            c.setCellValue(value);
            curColIndex++;
        }
        public void createCell(Date value){
            Cell c=curRow.createCell(curColIndex);
            if(styles.containsKey(curColIndex))
                c.setCellStyle(styles.get(curColIndex));
            else
                c.setCellStyle(defaultStyle);
            c.setCellValue(value);
            curColIndex++;
        }
        public void createCell(Calendar value){
            Cell c=curRow.createCell(curColIndex);
            if(styles.containsKey(curColIndex))
                c.setCellStyle(styles.get(curColIndex));
            else
                c.setCellStyle(defaultStyle);
            c.setCellValue(value);
            curColIndex++;
        }
        public void createCell(RichTextString value){
            Cell c=curRow.createCell(curColIndex);
            if(styles.containsKey(curColIndex))
                c.setCellStyle(styles.get(curColIndex));
            else
                c.setCellStyle(defaultStyle);
            c.setCellValue(value);
            curColIndex++;
        }
        
        /**
         * 将excel尾部描述列往后移动
         */
        private void moveData(){
            sheet.shiftRows(curRowIndex+1, lastRowIndex++, 1,true, true);    
        }
        /**
         * 设置序号 可选
         */
        public void insertSerial(){
            int serialRow=-1;
            int serialCol=-1;
            boolean findSerial=false;
            for(Row row:sheet){
                if(findSerial) break;
                for(Cell cell:row){
                    if(cell.getCellType()!=Cell.CELL_TYPE_STRING) continue;
                    String str=cell.getStringCellValue().trim();
                    if(str.equals("serial")){
                        serialRow=cell.getRowIndex();
                        serialCol=cell.getColumnIndex();
                        findSerial=true;
                        break;
                    }
                }
            }
            if(serialRow==-1 || serialCol==-1){
                return;
            }
            int count=curRowIndex-initRowIndex+1;
            for(int i=1;i<=count;i++){
                Cell c=sheet.getRow(serialRow++).createCell(serialCol);
                c.setCellValue(i);
            }
        }
        /**
         * 为一些变量赋值
         * @param datas
         */
        public void replaceVariable(Map<String,String> datas){
            for(Row row:sheet){
                for(Cell cell:row){
                    if(cell.getCellType()!=Cell.CELL_TYPE_STRING) continue;
                    String str=cell.getStringCellValue().trim();
                    if(!str.startsWith("#")) continue;
                    if(datas.containsKey(str.substring(1))){
                        cell.setCellValue(datas.get(str.substring(1)));
                    }
                }
            }
        }
    }
    package com.util;
    
    import java.io.File;
    import java.io.FileNotFoundException;
    import java.io.FileOutputStream;
    import java.io.IOException;
    import java.io.InputStream;
    import java.io.OutputStream;
    import java.lang.reflect.Field;
    import java.lang.reflect.InvocationTargetException;
    import java.util.ArrayList;
    import java.util.Collections;
    import java.util.HashMap;
    import java.util.List;
    import java.util.Map;
    import java.util.Properties;
    import java.util.Set;
    
    import org.apache.commons.beanutils.BeanUtils;
    import org.apache.poi.EncryptedDocumentException;
    import org.apache.poi.hssf.usermodel.HSSFWorkbook;
    import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
    import org.apache.poi.ss.usermodel.Cell;
    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;
    import org.apache.poi.xssf.usermodel.XSSFWorkbook;
    
    import com.ann.Column;
    
    
    /**
     * 对象和excel之间的互相转换
     * 使用模板写入excel与不使用模板写入
     * 读取excel数据到对象集合
     * @author Administrator
     *
     */
    @SuppressWarnings({"rawtypes","unchecked"})
    public class ExcelUtil {
        private static ExcelUtil eu=new ExcelUtil();
        /**
         * 单例
         */
        private ExcelUtil(){}
        /**
         * excel字段内容对象集合
         */
        private List<ExcelHeader> headers;
        
        public static ExcelUtil getInstance(){
            return eu;
        }
        /**
         * 模板对象
         */
        private ExcelTemplate et;
        /**
         * excel工作薄对象
         */
        private Workbook wb;
        /**
         * 将对象插入到excel表格中,使用模板,目标是文件
         * @param datas
         * @param alertableValues
         * @param objectClassType
         * @param path
         * @param isFilePath
         * @param outPath
         */
        public void Obj2ExcelUseTemplate(List<Object> datas,Map<String,String> alertableValues,Class objectClassType,String path,boolean isFilePath,String outPath){
            et=isFilePath?ExcelTemplate.getInstance().readTemplateByFilepath(path):ExcelTemplate.getInstance().readTemplateByClasspath(path);
            try {
                handerObj2ExcelUseTemplate(datas,alertableValues,objectClassType);
                
                et.writeToFile(outPath);
            } catch (IllegalAccessException e) {
                e.printStackTrace();
            } catch (InvocationTargetException e) {
                e.printStackTrace();
            } catch (NoSuchMethodException e) {
                e.printStackTrace();
            } catch (InstantiationException e) {
                e.printStackTrace();
            }
        }
        /**
         * 将对象插入到excel表格中,使用模板,目标是输出流
         * @param datas
         * @param alertableValues
         * @param objectClassType
         * @param path
         * @param isFilePath
         * @param os
         */
        public void Obj2ExcelUseTemplate(List<Object> datas,Map<String,String> alertableValues,Class objectClassType,String path,boolean isFilePath,OutputStream os){
            et=isFilePath?ExcelTemplate.getInstance().readTemplateByFilepath(path):ExcelTemplate.getInstance().readTemplateByClasspath(path);
            try {
                handerObj2ExcelUseTemplate(datas,alertableValues,objectClassType);
                et.writeToStream(os);
            } catch (IllegalAccessException e) {
                e.printStackTrace();
            } catch (InvocationTargetException e) {
                e.printStackTrace();
            } catch (NoSuchMethodException e) {
                e.printStackTrace();
            } catch (InstantiationException e) {
                e.printStackTrace();
            }
        }
        /**
         * 将对象插入到excel表格中,使用模板,目标是文件
         * @param datas
         * @param alertableValues
         * @param objectClassType
         * @param path
         * @param isFilePath
         * @param outPath
         */
        
        public void Obj2ExcelUseTemplate(List<Object> datas,Properties prop,Class objectClassType,String path,boolean isFilePath,String outPath){
            et=isFilePath?ExcelTemplate.getInstance().readTemplateByFilepath(path):ExcelTemplate.getInstance().readTemplateByClasspath(path);
            try {
                Map maps=new HashMap<String,String>();
                if(!(prop==null || prop.size()==0)) maps.putAll(prop);
                handerObj2ExcelUseTemplate(datas,maps,objectClassType);
                et.writeToFile(outPath);
            } catch (IllegalAccessException e) {
                e.printStackTrace();
            } catch (InvocationTargetException e) {
                e.printStackTrace();
            } catch (NoSuchMethodException e) {
                e.printStackTrace();
            } catch (InstantiationException e) {
                e.printStackTrace();
            }
        }
        /**
         * 将对象插入到excel表格中,使用模板,目标是输出流
         * @param datas
         * @param alertableValues
         * @param objectClassType
         * @param path
         * @param isFilePath
         * @param os
         */
        public void Obj2ExcelUseTemplate(List<Object> datas,Properties prop,Class objectClassType,String path,boolean isFilePath,OutputStream os){
            et=isFilePath?ExcelTemplate.getInstance().readTemplateByFilepath(path):ExcelTemplate.getInstance().readTemplateByClasspath(path);
            try {
                Map maps=new HashMap<String,String>();
                if(!(prop==null || prop.size()==0)) maps.putAll(prop);
                handerObj2ExcelUseTemplate(datas,maps,objectClassType);
                et.writeToStream(os);
            } catch (IllegalAccessException e) {
                e.printStackTrace();
            } catch (InvocationTargetException e) {
                e.printStackTrace();
            } catch (NoSuchMethodException e) {
                e.printStackTrace();
            } catch (InstantiationException e) {
                e.printStackTrace();
            }
        }
        /**
         * 使用模板将对象插入Excel中的转换工作的方法
         * @param datas
         * @param alertableValues
         * @param objectClassType
         * @throws IllegalAccessException
         * @throws InvocationTargetException
         * @throws NoSuchMethodException
         * @throws InstantiationException
         */
        private void handerObj2ExcelUseTemplate(List<Object> datas,Map<String,String> alertableValues,Class objectClassType) throws IllegalAccessException, InvocationTargetException, NoSuchMethodException, InstantiationException{
            headers=getHeaderList(objectClassType);
            Collections.sort(headers);
            for(ExcelHeader eh:headers){//设置标题
                et.createCell(eh.getTitle());
            }
            for(Object o:datas){
                et.createNewRow();
                for(ExcelHeader eh:headers){
                    et.createCell(BeanUtils.getProperty(o, eh.getFieldName()));
                }
            }
            if(alertableValues==null || alertableValues.size()==0) return;
            et.replaceVariable(alertableValues);
        }
        /**
         * 获取excel字段内容对象集合
         * @param clz
         * @return
         */
        private List<ExcelHeader> getHeaderList(Class clz) {
            List<ExcelHeader> headers=new ArrayList<ExcelHeader>();
            Field[] fields=clz.getDeclaredFields();
            for(Field f:fields){
                if(f.isAnnotationPresent(Column.class)){
                    Column c=f.getAnnotation(Column.class);
                    headers.add(new ExcelHeader(c.title(), c.order(), f.getName()));
                }
            }
            return headers;
        }
        /**
         * 对象写入excel文件
         * @param isXSSF
         * @param datas
         * @param objectClassType
         * @param outPath
         */
        public void Obj2Excel(boolean isXSSF,List<Object> datas,Class objectClassType,String outPath){
            wb=isXSSF?(new XSSFWorkbook()):(new HSSFWorkbook());
            try {
                Obj2Excel(datas,objectClassType);
                writeToFile(outPath);
            } catch (IllegalAccessException e) {
                e.printStackTrace();
            } catch (InvocationTargetException e) {
                e.printStackTrace();
            } catch (NoSuchMethodException e) {
                e.printStackTrace();
            }    
        }
        /**
         * 对象写入excel文件 流
         * @param isXSSF
         * @param datas
         * @param objectClassType
         * @param os
         */
        public void Obj2Excel(boolean isXSSF,List<Object> datas,Class objectClassType,OutputStream os){
            wb=isXSSF?(new XSSFWorkbook()):(new HSSFWorkbook());
            try {
                Obj2Excel(datas,objectClassType);
                writeToStream(os);
            } catch (IllegalAccessException e) {
                e.printStackTrace();
            } catch (InvocationTargetException e) {
                e.printStackTrace();
            } catch (NoSuchMethodException e) {
                e.printStackTrace();
            }    
        }
        /**
         * 将Workbook写入文件
         * @param outPath
         */
        private void writeToFile(String outPath) {
            FileOutputStream fos=null;
            try {
                fos = new FileOutputStream(outPath);
                wb.write(fos);
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }finally{
                try {
                    if(fos!=null) fos.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
        /**
         * 将Workbook写入输出流
         * @param os
         */
        private void writeToStream(OutputStream os){
            try {
                wb.write(os);
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        /**
         * 处理将对象转换成excel的具体实现,不使用模板
         * @param datas
         * @param objectClassType
         * @throws IllegalAccessException
         * @throws InvocationTargetException
         * @throws NoSuchMethodException
         */
        private void Obj2Excel(List<Object> datas,Class objectClassType) throws IllegalAccessException, InvocationTargetException, NoSuchMethodException{
            Sheet sheet=wb.createSheet();
            Row r=sheet.createRow(0);
            //插入表头
            headers=getHeaderList(objectClassType);
            Collections.sort(headers);
            for(int i=0;i<headers.size();i++){
                Cell c=r.createCell(i);
                c.setCellValue(headers.get(i).getTitle());
            }
            //插入数据内容
            for(int i=0;i<datas.size();i++){
                r=sheet.createRow(i+1);
                for(int j=0;j<headers.size();j++){
                    Cell c=r.createCell(j);
                    c.setCellValue(BeanUtils.getProperty(datas.get(i),headers.get(j).getFieldName()));
                }
            }
        }
        /**
         * 从流中读取表格信息到对象集合
         * @param ins
         * @param objectClassType
         * @param readLine
         * @param tailLine
         * @return
         */
        public List<Object> readExcel2Objs(InputStream ins,Class objectClassType,int readLine,int tailLine){
            try {
                wb=WorkbookFactory.create(ins);
                return handerReadExcel2Objs(objectClassType,readLine,tailLine);
            } catch (EncryptedDocumentException e) {
                e.printStackTrace();
            } catch (InvalidFormatException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            } catch (InstantiationException e) {
                e.printStackTrace();
            } catch (IllegalAccessException e) {
                e.printStackTrace();
            } catch (InvocationTargetException e) {
                e.printStackTrace();
            }
            return null;
        }
        /**
         * 从文件中读取表格信息到对象集合
         * @param filePath
         * @param objectClassType
         * @param readLine
         * @param tailLine
         * @return
         */
        public List<Object> readExcel2Objs(String filePath,Class objectClassType,int readLine,int tailLine){
            try {
                wb=WorkbookFactory.create(new File(filePath));
                return handerReadExcel2Objs(objectClassType,readLine,tailLine);
            } catch (EncryptedDocumentException e) {
                e.printStackTrace();
            } catch (InvalidFormatException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            } catch (InstantiationException e) {
                e.printStackTrace();
            } catch (IllegalAccessException e) {
                e.printStackTrace();
            } catch (InvocationTargetException e) {
                e.printStackTrace();
            }
            return null;
        }
        /**
         * 转换表格信息到对象集合的实现方法
         * @param objectClassType
         * @param readLine
         * @param tailLine
         * @return
         * @throws InstantiationException
         * @throws IllegalAccessException
         * @throws InvocationTargetException
         */
        private List<Object> handerReadExcel2Objs(Class objectClassType,int readLine,int tailLine) throws InstantiationException, IllegalAccessException, InvocationTargetException{
            List<Object> objs=new ArrayList<Object>();
            Sheet sheet=wb.getSheetAt(0);
            Map<Integer,String> headerMap=getHeaderMap(sheet.getRow(readLine),objectClassType);//列数和字段的map集合
            for(int i=readLine+1;i<sheet.getLastRowNum()-tailLine+1;i++){
                Row r=sheet.getRow(i);
                Object o=objectClassType.newInstance();
                Set<Integer> cols=headerMap.keySet();
                for(int x:cols){
                    Cell c=r.getCell(x);
                    BeanUtils.copyProperty(o, headerMap.get(x), getCellValue(c));
                }
                objs.add(o);
            }
            return objs;
        }
        /**
         * 获取不同值的方法
         * @param cell
         * @return
         */
        private Object getCellValue(Cell cell){
            int type=cell.getCellType();
            String show=null;
            switch(type){
            case Cell.CELL_TYPE_BLANK:
                show=null;break;
            case Cell.CELL_TYPE_BOOLEAN:
                show= String.valueOf(cell.getBooleanCellValue());break;
            case Cell.CELL_TYPE_ERROR:
                show=String.valueOf(cell.getErrorCellValue());break;
            case Cell.CELL_TYPE_FORMULA:
                show=cell.getCellFormula();break;
            case Cell.CELL_TYPE_NUMERIC:
                show=String.valueOf(cell.getNumericCellValue());break;
            case Cell.CELL_TYPE_STRING:
                show=cell.getStringCellValue();break;
            default:
                show=null;
            }
            return show;
        }
        /**
         * 获取列和对应字段的映射集合
         */
        public Map<Integer,String> getHeaderMap(Row r,Class objectClassType){
            headers=getHeaderList(objectClassType);
            Collections.sort(headers);
            Map<Integer,String> maps=new HashMap<Integer,String>();
            for(Cell c:r){
                String title=c.getStringCellValue();
                for(ExcelHeader eh:headers){
                    if(title.equals(eh.getTitle())){
                        maps.put(c.getColumnIndex(), eh.getFieldName());
                        break;
                    }
                }
            }
            return maps;
        }
    }
    
    一个用来测试的properties:
    title="User Message List"
    date="2016-7-11"
    author="guodaxia"
    View Code
  • 相关阅读:
    Asp.net Mvc中MVCContrib中无法使用Castle的发解决方案
    Asp.net Mvc Framework 十(测试方法及Filter的示例)
    无注册表的COM调用
    Direct3D 9学习笔记(13)网格(Mesh)4
    Direct3D 9学习笔记(11)网格(Mesh)2
    ATL 核心COM继承类之IDispatchImpl及调用
    ATL 核心COM继承类之CComObjectRootEx及CComObjectLock
    Direct3D 9学习笔记(12)网格(Mesh)3
    ATL COM类之激活
    ATL 引用计数线程模型
  • 原文地址:https://www.cnblogs.com/aigeileshei/p/5662937.html
Copyright © 2020-2023  润新知