EN · DE · RU · FR · ES

#387: ExcelImport.java

projectforge-business/src/main/java/org/projectforge/business/excel/ExcelImport.java Java-класс, projectforge-business/src/main/java/org/projectforge/business/excel/ExcelImport.java 353 строки · 203 кода · 126 комментариев · 24 пустых
Назначение: Исходный файл: projectforge/business/excel/ExcelImport.java. ExcelImport.java является частью приложения для управления проектами с открытым исходным кодом ProjectForge.

Исходный код (первые 100 строк)

/////////////////////////////////////////////////////////////////////////////
//
// Project ProjectForge Community Edition
//         www.projectforge.org
//
// Copyright (C) 2001-2026 Micromata GmbH, Germany (www.micromata.com)
//
// ProjectForge распространяется по двойной лицензии.
//
// Эта версия для сообщества является бесплатным программным обеспечением; вы можете распространять и/или
// изменять её в соответствии с условиями Стандартной общественной лицензии GNU (GNU General Public License)
// в том виде, в каком она опубликована Фондом свободного программного обеспечения; версия 3 лицензии.
//
// Эта версия для сообщества распространяется в надежде, что она будет полезной,
// но БЕЗ КАКИХ-ЛИБО ГАРАНТИЙ; даже без подразумеваемой гарантии
// КОММЕРЧЕСКОЙ ЦЕННОСТИ или ПРИГОДНОСТИ ДЛЯ ОПРЕДЕЛЁННОЙ ЦЕЛИ. См. GNU General
// Public License для получения более подробной информации.
//
// Вы должны были получить копию Стандартной общественной лицензии GNU вместе
// с этой программой; если нет, см. http://www.gnu.org/licenses/.
//
/////////////////////////////////////////////////////////////////////////////

package org.projectforge.business.excel;

import org.apache.commons.beanutils.ConvertUtils;
import org.apache.commons.beanutils.PropertyUtils;
import org.apache.commons.lang3.ClassUtils;
import org.apache.commons.lang3.StringUtils;
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 java.io.IOException;
import java.io.InputStream;
import java.lang.reflect.Array;
import java.lang.reflect.InvocationTargetException;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.Map;

/**
 * Преобразует заданный лист Excel в массив объектов.
 *
 * @param <T> базовый класс для каждой строки
 * @author Wolfgang Jung (w.jung@micromata.de)
 */
public class ExcelImport<T>
{
  /**
   * Логгер
   */
  private static final org.slf4j.Logger log = org.slf4j.LoggerFactory.getLogger(ExcelImport.class);

  /**
   * рабочая книга, содержащая значения.
   */
  private final HSSFWorkbook work;

  /**
   * необязательная карта для сопоставления имён столбцов с именами свойств.
   */
  private Map<String, String> columnToPropertyMap;

  /**
   * рабочий лист, из которого должны быть прочитаны значения.
   */
  private int activeSheet = 0;

  /**
   * индекс (с нуля) строки с именами столбцов
   */
  private int columnNameRow = 0;

  /**
   * индекс (с нуля) первой строки, содержащей значения
   */
  private int startAtRow = 1;

  /**
   * фабрика классов для создания объектов.
   */
  private ClassFactory<T> clazzFactory;

  /**
   * Открывает заданный Excel-документ. Поток всегда закрывается.
   *
   * @param xlsStream поток Excel-документа.
   * @throws IOException если документ не читается
   */
  public ExcelImport(final InputStream xlsStream) throws IOException
  {
    // Закрывается HSSFWorkbook
    work = new HSSFWorkbook(xlsStream);
  }

  /**
   * получить ссылку на рабочую книгу для специальных возможностей.

История Git

868d6abb7 2025 -> 2026
63081666f Заголовки исходных файлов: 2024-> 2025.
b6092df09 Авторское право 2023 -> 2024
ab45d51fa Авторское право 2001-2022 -> 2001-2023.
c06db1dab Почти все jar-файлы обновлены (требуются изменения кода).

868d6abb7

2025 -> 2026
868d6abb75cd191a892911ac8e45058932cf9074
diff --git a/projectforge-business/src/main/java/org/projectforge/business/excel/ExcelImport.java b/projectforge-business/src/main/java/org/projectforge/business/excel/ExcelImport.java
index e3598d29b..dbb1c0d48 100644
--- a/projectforge-business/src/main/java/org/projectforge/business/excel/ExcelImport.java
+++ b/projectforge-business/src/main/java/org/projectforge/business/excel/ExcelImport.java
@@ -3,7 +3,7 @@
 // Project ProjectForge Community Edition
 //         www.projectforge.org
 //
-// Copyright (C) 2001-2025 Micromata GmbH, Germany (www.micromata.com)
+// Copyright (C) 2001-2026 Micromata GmbH, Germany (www.micromata.com)
 //
 // ProjectForge is dual-licensed.
 //

63081666f

Заголовки исходных файлов: 2024-> 2025.
63081666f620fb87315f01b817e560e0b2f6a33a
diff --git a/projectforge-business/src/main/java/org/projectforge/business/excel/ExcelImport.java b/projectforge-business/src/main/java/org/projectforge/business/excel/ExcelImport.java
index 8a1c8f2d9..e3598d29b 100644
--- a/projectforge-business/src/main/java/org/projectforge/business/excel/ExcelImport.java
+++ b/projectforge-business/src/main/java/org/projectforge/business/excel/ExcelImport.java
@@ -3,7 +3,7 @@
 // Project ProjectForge Community Edition
 //         www.projectforge.org
 //
-// Copyright (C) 2001-2024 Micromata GmbH, Germany (www.micromata.com)
+// Copyright (C) 2001-2025 Micromata GmbH, Germany (www.micromata.com)
 //
 // ProjectForge is dual-licensed.
 //

b6092df09

Авторское право 2023 -> 2024
b6092df0927c4a3b161e888445f31dcab57493f2
diff --git a/projectforge-business/src/main/java/org/projectforge/business/excel/ExcelImport.java b/projectforge-business/src/main/java/org/projectforge/business/excel/ExcelImport.java
index 3189f78de..8a1c8f2d9 100644
--- a/projectforge-business/src/main/java/org/projectforge/business/excel/ExcelImport.java
+++ b/projectforge-business/src/main/java/org/projectforge/business/excel/ExcelImport.java
@@ -3,7 +3,7 @@
 // Project ProjectForge Community Edition
 //         www.projectforge.org
 //
-// Copyright (C) 2001-2023 Micromata GmbH, Germany (www.micromata.com)
+// Copyright (C) 2001-2024 Micromata GmbH, Germany (www.micromata.com)
 //
 // ProjectForge is dual-licensed.
 //

ab45d51fa

Авторское право 2001-2022 -> 2001-2023.
ab45d51fa419ede6174b31d69987f96d4b841ff9
diff --git a/projectforge-business/src/main/java/org/projectforge/business/excel/ExcelImport.java b/projectforge-business/src/main/java/org/projectforge/business/excel/ExcelImport.java
index 41f18bd64..3189f78de 100644
--- a/projectforge-business/src/main/java/org/projectforge/business/excel/ExcelImport.java
+++ b/projectforge-business/src/main/java/org/projectforge/business/excel/ExcelImport.java
@@ -3,7 +3,7 @@
 // Project ProjectForge Community Edition
 //         www.projectforge.org
 //
-// Copyright (C) 2001-2022 Micromata GmbH, Germany (www.micromata.com)
+// Copyright (C) 2001-2023 Micromata GmbH, Germany (www.micromata.com)
 //
 // ProjectForge is dual-licensed.
 //

c06db1dab

Почти все jar-файлы обновлены (требуются изменения кода).
c06db1dab7a4f114f726cfa4ebcf3716bb1d321f
diff --git a/projectforge-business/src/main/java/org/projectforge/business/excel/ExcelImport.java b/projectforge-business/src/main/java/org/projectforge/business/excel/ExcelImport.java
index a0c4b4380..41f18bd64 100644
--- a/projectforge-business/src/main/java/org/projectforge/business/excel/ExcelImport.java
+++ b/projectforge-business/src/main/java/org/projectforge/business/excel/ExcelImport.java
@@ -325,7 +325,7 @@ public class ExcelImport<T>
     if (cell == null) {
       return null;
     }
-    switch (cell.getCellTypeEnum()) {
+    switch (cell.getCellType()) {
       case NUMERIC:
         log.debug("using numeric");
         if (Date.class.isAssignableFrom(destClazz)) {