EN · DE · RU · FR · ES

#387 : ExcelImport.java

projectforge-business/src/main/java/org/projectforge/business/excel/ExcelImport.java Classe Java, projectforge-business/src/main/java/org/projectforge/business/excel/ExcelImport.java 353 lignes · 203 code · 126 commentaires · 24 vides
Objectif : Fichier source : projectforge/business/excel/ExcelImport.java. ExcelImport.java fait partie de l'application open-source de gestion de projet ProjectForge.

Source (100 premières lignes)

/////////////////////////////////////////////////////////////////////////////
//
// Projet ProjectForge Community Edition
//         www.projectforge.org
//
// Copyright (C) 2001-2026 Micromata GmbH, Allemagne (www.micromata.com)
//
// ProjectForge est sous double licence.
//
// Cette édition communautaire est un logiciel libre ; vous pouvez la redistribuer et/ou
// la modifier selon les termes de la GNU General Public License telle que publiée
// par la Free Software Foundation ; version 3 de la Licence.
//
// Cette édition communautaire est distribuée dans l'espoir qu'elle sera utile,
// mais SANS AUCUNE GARANTIE ; sans même la garantie implicite de
// COMMERCIALISATION ou D'ADÉQUATION À UN USAGE PARTICULIER. Voir la GNU General
// Public License pour plus de détails.
//
// Vous devriez avoir reçu une copie de la GNU General Public License avec
// ce programme ; sinon, consultez 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;

/**
 * Convertit une feuille Excel donnée en un tableau d'objets.
 *
 * @param <T> classe de base pour chaque ligne
 * @author Wolfgang Jung (w.jung@micromata.de)
 */
public class ExcelImport<T>
{
  /**
   * Le logger
   */
  private static final org.slf4j.Logger log = org.slf4j.LoggerFactory.getLogger(ExcelImport.class);

  /**
   * le classeur contenant les valeurs.
   */
  private final HSSFWorkbook work;

  /**
   * une map optionnelle pour mapper les noms de colonnes aux noms de propriétés.
   */
  private Map<String, String> columnToPropertyMap;

  /**
   * la feuille de calcul à partir de laquelle les valeurs doivent être lues.
   */
  private int activeSheet = 0;

  /**
   * l'index basé sur zéro contenant les noms de colonnes
   */
  private int columnNameRow = 0;

  /**
   * l'index basé sur zéro de la première ligne contenant des valeurs
   */
  private int startAtRow = 1;

  /**
   * la fabrique de classes pour créer les objets.
   */
  private ClassFactory<T> clazzFactory;

  /**
   * Ouvre un document Excel donné. Le flux est toujours fermé.
   *
   * @param xlsStream le flux du document Excel.
   * @throws IOException si le document n'est pas lisible
   */
  public ExcelImport(final InputStream xlsStream) throws IOException
  {
    // Fermé par HSSFWorkbook
    work = new HSSFWorkbook(xlsStream);
  }

  /**
   * obtient une référence au classeur pour des fonctionnalités spéciales.

Historique Git

868d6abb7 2025 -> 2026
63081666f En-têtes des fichiers source : 2024 -> 2025.
b6092df09 Copyright 2023 -> 2024
ab45d51fa Copyright 2001-2022 -> 2001-2023.
c06db1dab Presque tous les jars mis à jour (modifications de code nécessaires).

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 @@
 // Projet ProjectForge Community Edition
 //         www.projectforge.org
 //
-// Copyright (C) 2001-2025 Micromata GmbH, Allemagne (www.micromata.com)
+// Copyright (C) 2001-2026 Micromata GmbH, Allemagne (www.micromata.com)
 //
 // ProjectForge est sous double licence.
 //

63081666f

En-têtes des fichiers source : 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 @@
 // Projet ProjectForge Community Edition
 //         www.projectforge.org
 //
-// Copyright (C) 2001-2024 Micromata GmbH, Allemagne (www.micromata.com)
+// Copyright (C) 2001-2025 Micromata GmbH, Allemagne (www.micromata.com)
 //
 // ProjectForge est sous double licence.
 //

b6092df09

Copyright 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 @@
 // Projet ProjectForge Community Edition
 //         www.projectforge.org
 //
-// Copyright (C) 2001-2023 Micromata GmbH, Allemagne (www.micromata.com)
+// Copyright (C) 2001-2024 Micromata GmbH, Allemagne (www.micromata.com)
 //
 // ProjectForge est sous double licence.
 //

ab45d51fa

Copyright 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 @@
 // Projet ProjectForge Community Edition
 //         www.projectforge.org
 //
-// Copyright (C) 2001-2022 Micromata GmbH, Allemagne (www.micromata.com)
+// Copyright (C) 2001-2023 Micromata GmbH, Allemagne (www.micromata.com)
 //
 // ProjectForge est sous double licence.
 //

c06db1dab

Presque tous les jars mis à jour (modifications de code nécessaires).
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)) {