https://issues.apache.org/bugzilla/show_bug.cgi?id=51601

             Bug #: 51601
           Summary: Excel 2003 and 2007 can not open file generated by poi
                    if the number of sheet in a workbook exceed 1370
                    sheets
           Product: POI
           Version: 3.7
          Platform: PC
        OS/Version: Linux
            Status: NEW
          Severity: normal
          Priority: P2
         Component: HSSF
        AssignedTo: dev@poi.apache.org
        ReportedBy: fe...@sanchezit.com
    Classification: Unclassified


Created attachment 27341
  --> https://issues.apache.org/bugzilla/attachment.cgi?id=27341
Corrupted file created by poi 3.7, workbook with 1371 sheets

I use the version of POI(3.7) to create 1400 sheets in a workbook. And when I
open the XLS file generated by the programe, the MS excel 2003 pops the error
like bellow. 

Damage to the file was so extensive that repairs were not possible.  Excel
attempted to recover your formulas and values, but some data may have been
lost or corrupted.

In addition,  if the number of sheet is under 1370, it can be opened normally. 
Also when I use POI 2.5.1 the workbook is generated fine.

Attached is the generated file and here is the test code:

package com.test;

import java.io.FileOutputStream;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.ss.usermodel.Cell;

import org.apache.poi.ss.usermodel.CellStyle;
import org.apache.poi.ss.usermodel.Font;
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.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.DataFormat;
//import org.apache.poi.ss.util.Color;
//import org.apache.poi.ss.util.Region;
public class poiTest36 {

    Workbook m_wb;
    Font m_boldFont;
    CellStyle cellStyle;
    poiTest36() {
        m_wb = new HSSFWorkbook();

        m_boldFont = m_wb.createFont();
        m_boldFont.setBoldweight( Font.BOLDWEIGHT_BOLD );
        cellStyle=m_wb.createCellStyle();

    }

    public void createSheet(){
        Sheet sheet=m_wb.createSheet();



        cellStyle.setFont(m_boldFont);
        cellStyle.setBorderBottom( CellStyle.BORDER_MEDIUM );
        cellStyle.setBorderRight( CellStyle.BORDER_MEDIUM );
        cellStyle.setBorderLeft( CellStyle.BORDER_MEDIUM);
        cellStyle.setBorderTop( CellStyle.BORDER_MEDIUM);
        Row row=sheet.createRow(1);

        Cell cell=row.createCell((short)1);
        cell.setCellStyle(cellStyle);
        cell.setCellValue("Felix S");
    }

    public void save( String filename) throws Exception  {

        FileOutputStream fileout = new FileOutputStream( filename );
        m_wb.write( fileout );
        fileout.close();                
    }

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        poiTest36 p = new poiTest36();
        for(int i=0; i<1371; i++) {
            p.createSheet();
        }
        try {
        p.save("/home/fsanchez/tmp/test.xls");
        }
        catch (Exception e){
            System.out.println("got exeption:" + e.getMessage());
            e.printStackTrace();
        }
    }

}

-- 
Configure bugmail: https://issues.apache.org/bugzilla/userprefs.cgi?tab=email
------- You are receiving this mail because: -------
You are the assignee for the bug.

---------------------------------------------------------------------
To unsubscribe, e-mail: dev-unsubscr...@poi.apache.org
For additional commands, e-mail: dev-h...@poi.apache.org

Reply via email to