JAVA异常---错误:索引:7,大小:7读取excel时异常:索引:7,大小:7

时间:2013-09-20 10:06:34

标签: java excel exception indexoutofboundsexception

在上传excel时遇到了一些问题。

以下是这段代码。

fileStream = new FileInputStream(dirToStore+filename);

        exReader = new ExcelReader(fileStream);
        workbook = exReader.getWorkBook();
        sheet = getDataSheet(workbook, out);
        List rowList = sheet.getAllRows();
        noRows = rowList.size();

        fileStream = new FileInputStream(dirToStore+filename);

        exReader = new ExcelReader(fileStream);
        workbook = exReader.getWorkBook();
        sheet = getDataSheet(workbook, out);
        List rowList = sheet.getAllRows();
        noRows = rowList.size();

int BATCH_SIZE = 1000;
            for (int i = 1; i < noRows; i++) {
                row = (Row) rowList.get(i);

                cellList = row.getAllCells();

                org_Code = ((Cell) cellList.get(0)).getName();
                prod_Family = ((Cell) cellList.get(1)).getName();
                buss_Unit = ((Cell) cellList.get(2)).getName();
                class_code = ((Cell) cellList.get(3)).getName();
                current_Buyer = ((Cell) cellList.get(4)).getName();
                new_Buyer = ((Cell) cellList.get(5)).getName();
                item = ((Cell) cellList.get(6)).getName();
                item_Revision = ((Cell) cellList.get(7)).getName();
                description = ((Cell) cellList.get(8)).getName();
                parent_Item_Number = ((Cell) cellList.get(9)).getName();
                type = ((Cell) cellList.get(10)).getName();
                purchasable = ((Cell) cellList.get(11)).getName();

                if(((Cell) cellList.get(12)) != null && !"".equals(((Cell) cellList.get(12))))
                global_Part_Flag = ((Cell) cellList.get(12)).getName();
                else
                global_Part_Flag = "";

                if (org_Code.equalsIgnoreCase("") && current_Buyer.equalsIgnoreCase("")&& new_Buyer.equalsIgnoreCase("") && item.equalsIgnoreCase(""))
                    continue;

                System.out.println("org_Code=========> " + org_Code);
                System.out.println("prod_Family=========> " + prod_Family);
                System.out.println("buss_Unit=========> " + buss_Unit);
                System.out.println("class_code=========> " + class_code);
                System.out.println("current_Buyer=========> " + current_Buyer);
                System.out.println("new_Buyer=========> " + new_Buyer);
                System.out.println("item=========> " + item);
                System.out.println("item_Revision=========> " + item_Revision);
                System.out.println("description=========> " + description);
                System.out.println("parent_Item_Number=========> " + parent_Item_Number);
                System.out.println("type=========> " + type);
                System.out.println("purchasable=========> " + purchasable);
                System.out.println("global_Part_Flag=========> " + global_Part_Flag);

                pstmt.setInt(1, groupId);
                pstmt.setInt(2, i);
                pstmt.setString(3, new_Buyer);
                pstmt.setString(4, current_Buyer);
                pstmt.setString(5, org_Code);
                pstmt.setString(6, prod_Family);
                pstmt.setString(7, buss_Unit);
                pstmt.setString(8, class_code);
                pstmt.setString(9, item);
                pstmt.setString(10, item_Revision);
                pstmt.setString(11, description);
                pstmt.setString(12, parent_Item_Number);
                pstmt.setString(13, type);
                pstmt.setString(14, purchasable);
                pstmt.setString(15, global_Part_Flag);
                pstmt.setString(16, userID);
                pstmt.setInt(17, Integer.parseInt(employeeNumber));
                pstmt.setTimestamp(18, sqlDate);
                pstmt.setInt(19, Integer.parseInt(employeeNumber));
                pstmt.setTimestamp(20, sqlDate);

                pstmt.addBatch();

                if (i % BATCH_SIZE == 0){
                    int [] updateCounts = pstmt.executeBatch();
                    pstmt.clearBatch();
                    System.out.println("updateCounts====>" + updateCounts.length);
                    if(updateCounts.length == 0)
                    updateFlag = "N";
                }
            }

            if ((noRows-1) % BATCH_SIZE != 0){
                int [] updateCounts1 = pstmt.executeBatch();
                pstmt.clearBatch();
                System.out.println("updateCounts1====>" + updateCounts1.length);
                if(updateCounts1.length == 0)
                updateFlag = "N";
            //  if(updateCounts1.length ==0)
            //      throw new EMException("Uploaded file has no data. Please modify and upload again !!!.");
            }

                if("N".equals(updateFlag)){
                    throw new EMException("Uploaded file has no data. Please modify and upload again !!!.");    
                }
            /*  System.out.println("Before exe");
                int [] updateCounts = pstmt.executeBatch();
                System.out.println("After exe"); */
                conn1.commit();

            }catch (EMException e) {
                conn1.rollback();
                throw new EMException (e.getMessage());
            }catch (Exception e) {
                conn1.rollback();
                System.out.println("error : " + e.getMessage());
                e.printStackTrace();
                throw new Exception (e.getMessage());
            }finally{
                if(conn1 !=null)
                    conn1.setAutoCommit(true);
                if(pstmt != null) pstmt.close();
                if(conn1 != null) conn1.close();
            }
            System.out.println("before submitRequest");
            submitRequest(groupId, userID,out);
            System.out.println("After submitRequest");
        }

    }catch (EMException e) {

        System.out.println(" Exception while reading the excel : " + e.getMessage());
        out.println("<br> <br><table border=1 align=center>");
        out.println("<tr bgcolor='#77BFC7'>");
        if("Error in ExcelReader".equalsIgnoreCase(e.getMessage()))
            out.println("<td> <font size=3> Error occurred while reading the Excel. Please make sure that upload file is saved in 2003-2007 xls format.</font></td>");
        else
            out.println("<td> <font size=3> " + e.getMessage() +"</font></td>");
        out.println("</tr>");
        out.println("</table><br><br>");
        return;
    }catch (Exception e) {
        System.out.println(" Exception while reading the excel : " + e.getMessage());
        out.println("<br> <br><table border=1 align=center>");
        out.println("<tr bgcolor='#77BFC7'>");
        out.println("<td> <font size=3> An error occurred while processing your request. Check logs for error details. </font></td>");
        out.println("</tr>");
        out.println("</table><br><br>");
        return;
    }

以下DETAILS是代码的输出

noRows=============> 34
groupId==========> 16602
org_Code=========> XY
prod_Family=========> 
buss_Unit=========> 
class_code=========> 
current_Buyer=========> 
new_Buyer=========> XYZ
item=========> 74-3163-01
item_Revision=========> 
description=========> 
parent_Item_Number=========> 
type=========> 
purchasable=========> 
global_Part_Flag=========> 
org_Code=========> XY
prod_Family=========> 
buss_Unit=========> 
class_code=========> 
current_Buyer=========> 
new_Buyer=========> XYZ
item=========> 74-3210-01
item_Revision=========> 
description=========> 
parent_Item_Number=========> 
type=========> 
purchasable=========> 
global_Part_Flag=========> 
org_Code=========> XY
prod_Family=========> 
buss_Unit=========> 
class_code=========> 
current_Buyer=========> 
new_Buyer=========> XYZ
item=========> 74-3202-01
item_Revision=========> 
description=========> 
parent_Item_Number=========> 
type=========> 
purchasable=========> 
global_Part_Flag=========> 
org_Code=========> XY
prod_Family=========> 
buss_Unit=========> 
class_code=========> 
current_Buyer=========> 
new_Buyer=========> XYZ
item=========> 74-3783-01
item_Revision=========> 
description=========> 
parent_Item_Number=========> 
type=========> 
purchasable=========> 
global_Part_Flag=========> 
org_Code=========> XY
prod_Family=========> 
buss_Unit=========> 
class_code=========> 
current_Buyer=========> 
new_Buyer=========> XYZ
item=========> 74-3230-01
item_Revision=========> 
description=========> 
parent_Item_Number=========> 
type=========> 
purchasable=========> 
global_Part_Flag=========> 
org_Code=========> XY
prod_Family=========> 
buss_Unit=========> 
class_code=========> 
current_Buyer=========> 
new_Buyer=========> XYZ
item=========> 39-0249-01
item_Revision=========> 
description=========> 
parent_Item_Number=========> 
type=========> 
purchasable=========> 
global_Part_Flag=========> 
org_Code=========> XY
prod_Family=========> 
buss_Unit=========> 
class_code=========> 
current_Buyer=========> 
new_Buyer=========> XYZ
item=========> 74-3204-01
item_Revision=========> 
description=========> 
parent_Item_Number=========> 
type=========> 
purchasable=========> 
global_Part_Flag=========> 
org_Code=========> XY
prod_Family=========> 
buss_Unit=========> 
class_code=========> 
current_Buyer=========> 
new_Buyer=========> XYZ
item=========> 74-3164-01
item_Revision=========> 
description=========> 
parent_Item_Number=========> 
type=========> 
purchasable=========> 
global_Part_Flag=========> 
org_Code=========> XY
prod_Family=========> 
buss_Unit=========> 
class_code=========> 
current_Buyer=========> 
new_Buyer=========> XYZ
item=========> 39-0246-01
item_Revision=========> 
description=========> 
parent_Item_Number=========> 
type=========> 
purchasable=========> 
global_Part_Flag=========> 
org_Code=========> XY
prod_Family=========> 
buss_Unit=========> 
class_code=========> 
current_Buyer=========> 
new_Buyer=========> XYZ
item=========> 39-0219-01
item_Revision=========> 
description=========> 
parent_Item_Number=========> 
type=========> 
purchasable=========> 
global_Part_Flag=========> 
org_Code=========> XY
prod_Family=========> 
buss_Unit=========> 
class_code=========> 
current_Buyer=========> 
new_Buyer=========> XYZ
item=========> 72-4146-01
item_Revision=========> 
description=========> 
parent_Item_Number=========> 
type=========> 
purchasable=========> 
global_Part_Flag=========> 
org_Code=========> XY
prod_Family=========> 
buss_Unit=========> 
class_code=========> 
current_Buyer=========> 
new_Buyer=========> XYZ
item=========> 39-0250-01
item_Revision=========> 
description=========> 
parent_Item_Number=========> 
type=========> 
purchasable=========> 
global_Part_Flag=========> 
org_Code=========> XY
prod_Family=========> 
buss_Unit=========> 
class_code=========> 
current_Buyer=========> 
new_Buyer=========> XYZ
item=========> 72-4143-01
item_Revision=========> 
description=========> 
parent_Item_Number=========> 
type=========> 
purchasable=========> 
global_Part_Flag=========> 
org_Code=========> XY
O prod_Family=========> 
O buss_Unit=========> 
O class_code=========> 
O current_Buyer=========> 
O new_Buyer=========> XYZ
O item=========> 74-3232-01
O item_Revision=========> 
O description=========> 
O parent_Item_Number=========> 
O type=========> 
O purchasable=========> 
O global_Part_Flag=========> 
O org_Code=========> XY
O prod_Family=========> 
O buss_Unit=========> 
O class_code=========> 
O current_Buyer=========> 
O new_Buyer=========> XYZ
O item=========> 39-0247-01
O item_Revision=========> 
O description=========> 
O parent_Item_Number=========> 
O type=========> 
O purchasable=========> 
O global_Part_Flag=========> 
error : Index: 7, Size: 7
Exception while reading the excel : Index: 7, Size: 7

我在网络应用程序中上传excel时遇到上述异常。

请帮我解决上述问题。我不是一个java家伙:)

1 个答案:

答案 0 :(得分:0)

你写了

cellList = row.getAllCells();

在此代码之后,您可以从cellList对象

获取值
org_Code = ((Cell) cellList.get(0)).getName();

但你没有在

之后进行任何检查
 cellList = row.getAllCells();

这一行什么时候这个列表只有5个对象而你正在尝试

item = ((Cell) cellList.get(6)).getName();
item_Revision = ((Cell) cellList.get(7)).getName();

你肯定会被提到你的异常。