加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

具有最大行的Java JXL异常

发布时间:2020-12-15 08:48:14 所属栏目:Java 来源:网络整理
导读:我正在从我的矢量创建一个excel表,其中包含127923条记录,当我尝试输入记录时,我会遇到异常. jxl.write.biff.RowsExceededException: The maximum number of rows permitted on a worksheet been exceeded at jxl.write.biff.WritableSheetImpl.getRowRecord(
我正在从我的矢量创建一个excel表,其中包含127923条记录,当我尝试输入记录时,我会遇到异常.

jxl.write.biff.RowsExceededException: The maximum number of rows permitted on a worksheet been exceeded
    at jxl.write.biff.WritableSheetImpl.getRowRecord(WritableSheetImpl.java:1214)
    at jxl.write.biff.WritableSheetImpl.addCell(WritableSheetImpl.java:1151)
    at com.ibm.database.excel.WriteExcel.addLabel(WriteExcel.java:176)
    at com.ibm.database.excel.WriteExcel.write(WriteExcel.java:76)
    at com.ibm.database.excel.FileGenerator.generateExcel(FileGenerator.java:13)
    at com.ibm.database.taxoreader.TaxonomyReader.main(TaxonomyReader.java:46)

我知道因为excel表不允许超过65536条记录,但是我的代码我试图创建一个新的表单,每次我达到60000标记,但它不起作用.任何人都可以告诉我,我做错了什么.这是我的代码.

public void write (Vector list) throws IOException,WriteException{
    int k=0,row=0,column=0;
    WritableFont times10pt = new WritableFont(WritableFont.TIMES,10);
    // Define the cell format
    times = new WritableCellFormat(times10pt);
    // Lets automatically wrap the cells
    times.setWrap(true);
    TaxonomyBean bean= null;
    File file = new File("Test.xls");
    WorkbookSettings wbSettings = new WorkbookSettings();
    wbSettings.setLocale(new Locale("en","EN"));
    WritableWorkbook workbook = Workbook.createWorkbook(file,wbSettings);  
    WritableSheet sheet= workbook.createSheet(""+k,k);
    for(int i=0,j=0;i<list.size();i++,j++){
        if(j==60000){
         k=k+1;
         workbook.createSheet(""+k,k);
         j=0;
        }
        sheet = workbook.getSheet(k);
        bean=(TaxonomyBean)list.elementAt(i);
        column=0;row=i;
        System.out.println("adding "+bean.getDescription()+" at "+j+" in "+k+" and i "+i);
        addLabel(sheet,column,row,bean.getDescription());
        column++;
        addLabel(sheet,bean.getTaxonomyDescription());
    }
    workbook.write();
    workbook.close();

}

解决方法

您可以用以下代码替换循环代码:

for(int i = 0;i < list.size();i++)
{
    if(i % 60000 == 0)
    {
        k++;
        workbook.createSheet("" + k,k);
    }

    sheet = workbook.getSheet(k);
    bean = (TaxonomyBean)list.elementAt(i);

    column = 0;
    row = i % 60000;

    addLabel(sheet,bean.getDescription());
    column++;
    addLabel(sheet,bean.getTaxonomyDescription());
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读