zoukankan      html  css  js  c++  java
  • 高效率导出

    BigGridDemo.java

    /* ====================================================================
       Licensed to the Apache Software Foundation (ASF) under one or more
       contributor license agreements.  See the NOTICE file distributed with
       this work for additional information regarding copyright ownership.
       The ASF licenses this file to You under the Apache License, Version 2.0
       (the "License"); you may not use this file except in compliance with
       the License.  You may obtain a copy of the License at
    
           http://www.apache.org/licenses/LICENSE-2.0
    
       Unless required by applicable law or agreed to in writing, software
       distributed under the License is distributed on an "AS IS" BASIS,
       WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
       See the License for the specific language governing permissions and
       limitations under the License.
    ==================================================================== */
    
    package org.apache.poi.xssf.usermodel.examples;
    
    import java.io.*;
    import java.util.*;
    import java.util.zip.ZipEntry;
    import java.util.zip.ZipFile;
    import java.util.zip.ZipOutputStream;
    
    import org.apache.poi.ss.usermodel.DateUtil;
    import org.apache.poi.ss.usermodel.IndexedColors;
    import org.apache.poi.ss.util.CellReference;
    import org.apache.poi.xssf.usermodel.*;
    
    /**
     * Demonstrates a workaround you can use to generate large workbooks and avoid OutOfMemory exception.
     *
     * The trick is as follows:
     * 1. create a template workbook, create sheets and global objects such as cell styles, number formats, etc.
     * 2. create an application that streams data in a text file
     * 3. Substitute the sheet in the template with the generated data
     *
     * @author Yegor Kozlov
     */
    00041 public class BigGridDemo {
        public static void main(String[] args) throws Exception {
    
            // Step 1. Create a template file. Setup sheets and workbook-level objects such as
            // cell styles, number formats, etc.
    
            XSSFWorkbook wb = new XSSFWorkbook();
            XSSFSheet sheet = wb.createSheet("Big Grid");
    
            Map<String, XSSFCellStyle> styles = createStyles(wb);
            //name of the zip entry holding sheet data, e.g. /xl/worksheets/sheet1.xml
            String sheetRef = sheet.getPackagePart().getPartName().getName();
    
            //save the template
            FileOutputStream os = new FileOutputStream("template.xlsx");
            wb.write(os);
            os.close();
    
            //Step 2. Generate XML file.
            File tmp = File.createTempFile("sheet", ".xml");
            Writer fw = new FileWriter(tmp);
            generate(fw, styles);
            fw.close();
    
            //Step 3. Substitute the template entry with the generated data
            FileOutputStream out = new FileOutputStream("big-grid.xlsx");
            substitute(new File("template.xlsx"), tmp, sheetRef.substring(1), out);
            out.close();
        }
    
        /**
         * Create a library of cell styles.
         */
    00074     private static Map<String, XSSFCellStyle> createStyles(XSSFWorkbook wb){
            Map<String, XSSFCellStyle> styles = new HashMap<String, XSSFCellStyle>();
            XSSFDataFormat fmt = wb.createDataFormat();
    
            XSSFCellStyle style1 = wb.createCellStyle();
            style1.setAlignment(XSSFCellStyle.ALIGN_RIGHT);
            style1.setDataFormat(fmt.getFormat("0.0%"));
            styles.put("percent", style1);
    
            XSSFCellStyle style2 = wb.createCellStyle();
            style2.setAlignment(XSSFCellStyle.ALIGN_CENTER);
            style2.setDataFormat(fmt.getFormat("0.0X"));
            styles.put("coeff", style2);
    
            XSSFCellStyle style3 = wb.createCellStyle();
            style3.setAlignment(XSSFCellStyle.ALIGN_RIGHT);
            style3.setDataFormat(fmt.getFormat("$#,##0.00"));
            styles.put("currency", style3);
    
            XSSFCellStyle style4 = wb.createCellStyle();
            style4.setAlignment(XSSFCellStyle.ALIGN_RIGHT);
            style4.setDataFormat(fmt.getFormat("mmm dd"));
            styles.put("date", style4);
    
            XSSFCellStyle style5 = wb.createCellStyle();
            XSSFFont headerFont = wb.createFont();
            headerFont.setBold(true);
            style5.setFillForegroundColor(IndexedColors.GREY_25_PERCENT.getIndex());
            style5.setFillPattern(XSSFCellStyle.SOLID_FOREGROUND);
            style5.setFont(headerFont);
            styles.put("header", style5);
    
            return styles;
        }
    
        private static void generate(Writer out, Map<String, XSSFCellStyle> styles) throws Exception {
    
            Random rnd = new Random();
            Calendar calendar = Calendar.getInstance();
    
            SpreadsheetWriter sw = new SpreadsheetWriter(out);
            sw.beginSheet();
    
            //insert header row
            sw.insertRow(0);
            int styleIndex = styles.get("header").getIndex();
            sw.createCell(0, "Title", styleIndex);
            sw.createCell(1, "% Change", styleIndex);
            sw.createCell(2, "Ratio", styleIndex);
            sw.createCell(3, "Expenses", styleIndex);
            sw.createCell(4, "Date", styleIndex);
    
            sw.endRow();
    
            //write data rows
            for (int rownum = 1; rownum < 100000; rownum++) {
                sw.insertRow(rownum);
    
                sw.createCell(0, "Hello, " + rownum + "!");
                sw.createCell(1, (double)rnd.nextInt(100)/100, styles.get("percent").getIndex());
                sw.createCell(2, (double)rnd.nextInt(10)/10, styles.get("coeff").getIndex());
                sw.createCell(3, rnd.nextInt(10000), styles.get("currency").getIndex());
                sw.createCell(4, calendar, styles.get("date").getIndex());
    
                sw.endRow();
    
                calendar.roll(Calendar.DAY_OF_YEAR, 1);
            }
            sw.endSheet();
        }
    
        /**
         *
         * @param zipfile the template file
         * @param tmpfile the XML file with the sheet data
         * @param entry the name of the sheet entry to substitute, e.g. xl/worksheets/sheet1.xml
         * @param out the stream to write the result to
         */
    00152       private static void substitute(File zipfile, File tmpfile, String entry, OutputStream out) throws IOException {
            ZipFile zip = new ZipFile(zipfile);
    
            ZipOutputStream zos = new ZipOutputStream(out);
    
            @SuppressWarnings("unchecked")
            Enumeration<ZipEntry> en = (Enumeration<ZipEntry>) zip.entries();
            while (en.hasMoreElements()) {
                ZipEntry ze = en.nextElement();
                if(!ze.getName().equals(entry)){
                    zos.putNextEntry(new ZipEntry(ze.getName()));
                    InputStream is = zip.getInputStream(ze);
                    copyStream(is, zos);
                    is.close();
                }
            }
            zos.putNextEntry(new ZipEntry(entry));
            InputStream is = new FileInputStream(tmpfile);
            copyStream(is, zos);
            is.close();
    
            zos.close();
        }
    
        private static void copyStream(InputStream in, OutputStream out) throws IOException {
            byte[] chunk = new byte[1024];
            int count;
            while ((count = in.read(chunk)) >=0 ) {
              out.write(chunk,0,count);
            }
        }
    
        /**
         * Writes spreadsheet data in a Writer.
         * (YK: in future it may evolve in a full-featured API for streaming data in Excel)
         */
    00188     public static class SpreadsheetWriter {
            private final Writer _out;
            private int _rownum;
    
            public SpreadsheetWriter(Writer out){
                _out = out;
            }
    
            public void beginSheet() throws IOException {
                _out.write("<?xml version="1.0" encoding="UTF-8"?>" +
                        "<worksheet xmlns="http://schemas.openxmlformats.org/spreadsheetml/2006/main">" );
                _out.write("<sheetData>
    ");
            }
    
            public void endSheet() throws IOException {
                _out.write("</sheetData>");
                _out.write("</worksheet>");
            }
    
            /**
             * Insert a new row
             *
             * @param rownum 0-based row number
             */
    00212         public void insertRow(int rownum) throws IOException {
                _out.write("<row r=""+(rownum+1)+"">
    ");
                this._rownum = rownum;
            }
    
            /**
             * Insert row end marker
             */
    00220         public void endRow() throws IOException {
                _out.write("</row>
    ");
            }
    
            public void createCell(int columnIndex, String value, int styleIndex) throws IOException {
                String ref = new CellReference(_rownum, columnIndex).formatAsString();
                _out.write("<c r=""+ref+"" t="inlineStr"");
                if(styleIndex != -1) _out.write(" s=""+styleIndex+""");
                _out.write(">");
                _out.write("<is><t>"+value+"</t></is>");
                _out.write("</c>");
            }
    
            public void createCell(int columnIndex, String value) throws IOException {
                createCell(columnIndex, value, -1);
            }
    
            public void createCell(int columnIndex, double value, int styleIndex) throws IOException {
                String ref = new CellReference(_rownum, columnIndex).formatAsString();
                _out.write("<c r=""+ref+"" t="n"");
                if(styleIndex != -1) _out.write(" s=""+styleIndex+""");
                _out.write(">");
                _out.write("<v>"+value+"</v>");
                _out.write("</c>");
            }
    
            public void createCell(int columnIndex, double value) throws IOException {
                createCell(columnIndex, value, -1);
            }
    
            public void createCell(int columnIndex, Calendar value, int styleIndex) throws IOException {
                createCell(columnIndex, DateUtil.getExcelDate(value, false), styleIndex);
            }
        }
    }
    

    http://libjakarta-poi-java.sourcearchive.com/documentation/3.6plus-pdfsg/BigGridDemo_8java-source.html

  • 相关阅读:
    2716 [Violet 3] 天使玩偶
    BZOJ1017魔兽地图DotR 樹形DP
    BZOJ1016最小生成树计数 最小生成树 + 排列组合
    BZOJ1014火星人prefix Splay維護序列 + 字符串哈希
    BZOJ1010玩具裝箱Toy
    BZOJ1009GT考试 DP + KMP + 矩陣快速冪
    BZOJ1008[HNOI2008]越狱
    BZOJ1006神奇的国度 弦圖染色 最大勢算法
    BZOJ1005明明的烦恼 Prufer + 分解質因數 + 高精度
    poj2182(线段树求序列第k小)
  • 原文地址:https://www.cnblogs.com/gangben/p/3231981.html
Copyright © 2011-2022 走看看