Ошибка при чтении листа Excel с использованием Java - PullRequest
10 голосов
/ 08 марта 2012

Я работаю с Spring / Hibernet, используя NetBeans 6.9.1.Я пытаюсь прочитать файл Excel (.xlsx- Office 2007).Код для чтения файла Excel выглядит следующим образом, используя Vactor для хранения данных из листа Excel.

import java.io.FileInputStream;
import java.util.Iterator;
import java.util.Vector;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import model.NewHibernateUtil;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
import org.hibernate.Session;
import org.springframework.validation.BindException;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.SimpleFormController;

private Vector importExcelSheet(ModelAndView mv)
{
    Vector cellVectorHolder = new Vector();
    try
    {         
        HSSFWorkbook myWorkBook = new HSSFWorkbook(new POIFSFileSystem(new FileInputStream("E:/Project/SpringHibernet/MultiplexTicketBookingNew/web/excelSheets/Country.xlsx")));
        HSSFSheet mySheet = myWorkBook.getSheetAt(0);
        Iterator rowIter = mySheet.rowIterator();
        System.out.println(mySheet.getRow(1).getCell(0));
        while(rowIter.hasNext())
        {
            HSSFRow myRow = (HSSFRow) rowIter.next();
            Iterator cellIter = myRow.cellIterator();
            Vector cellStoreVector=new Vector();
            while(cellIter.hasNext())
            {
                HSSFCell myCell = (HSSFCell) cellIter.next();
                cellStoreVector.addElement(myCell);
            }
            cellVectorHolder.addElement(cellStoreVector);
        }
    }
    catch (Exception e)
    {
        mv.addObject("msg", e.getMessage());
    }
    return cellVectorHolder;
}

Ниже приведен метод в моем Controller, который вызывает вышеуказанный метод для чтенияуказанный файл Excel


@Override
protected ModelAndView onSubmit(HttpServletRequest request, HttpServletResponse response, Object command, BindException errors) throws Exception
{
    ModelAndView mv=new ModelAndView();

    try
    {
        if(request.getParameter("import")!=null)
        {
            session=NewHibernateUtil.getSessionFactory().getCurrentSession();
            session.beginTransaction();

            Vector dataHolder=importExcelSheet(mv);
            for (int i=0;i<dataHolder.size(); i++)
            {
                Vector cellStoreVector=(Vector)dataHolder.elementAt(i);
                for (int j=0; j < cellStoreVector.size();j++)
                {
                    HSSFCell myCell = (HSSFCell)cellStoreVector.elementAt(j);
                    String st = myCell.toString();
                    System.out.println(st.substring(0,1)+"\t");
                }
                System.out.println();
            }

            session.flush();
            session.getTransaction().commit();
        }
    }
    catch (Exception e)
    {
        mv.addObject("msg", e.getMessage());
    }
    return mv;
}

При выполнении этого кода выдается следующее исключение:

Представленные данные отображаются в XML-формате Office 2007+.Вы вызываете ту часть POI, которая касается офисных документов OLE2.Вам нужно вызвать другую часть POI для обработки этих данных (например, XSSF вместо HSSF)

Я использую неверный источник или что-то еще не так с приведенным выше кодом?Какое решение?

Код взят от здесь .

Ответы [ 2 ]

39 голосов
/ 09 марта 2012

Ваш код в явном виде запрашивает HSSF, поэтому будет работать только с более старыми .xls (двоичными) файлами.

Если хотите, вы можете попросить POI автоматически определить, какой тип файла у вас есть, и выбрать подходящий тип HSSF или XSSF для вашего случая. Однако для этого вам нужно немного изменить свой код и использовать интерфейсы, а не конкретные классы (поэтому ваш код работает независимо от того, получаете вы объект HSSF или XSSF)

На веб-сайте POI есть руководство по внесению этих изменений , которое должно вам помочь.

В качестве примера, когда вы будете следовать этому, ваши первые несколько строк, которые были:

    HSSFWorkbook myWorkBook = new HSSFWorkbook(new POIFSFileSystem(new FileInputStream("E:/Project/SpringHibernet/MultiplexTicketBookingNew/web/excelSheets/Country.xlsx")));
    HSSFSheet mySheet = myWorkBook.getSheetAt(0);
    Iterator rowIter = mySheet.rowIterator();
    System.out.println(mySheet.getRow(1).getCell(0));

станет в новой системе:

    Workbook wb = WorkbookFactory.create(new File("/path/to/your/excel/file"));
    Sheet mySheet = wb.getSheetAt(0);
    Iterator<Row> rowIter = mySheet.rowIterator();
    System.out.println(mySheet.getRow(1).getCell(0));

Это будет работать как для файлов .xls, так и для файлов .xlsx

6 голосов
/ 24 апреля 2013

Вы также можете просто заменить HSSF на XSSF.

Убедитесь, что вы добавили poi-ooxml .jar в дополнение к poi .jar. poi-ooxml обеспечивает поддержку XSSF. Убедитесь, что вы также добавили данные зависимости, перечисленные на странице компонентов Apache POI .

...