EN · DE · RU · FR · ES

#454 : ExportMSProject.java

projectforge-business/src/main/java/org/projectforge/business/gantt/ExportMSProject.java Type : Java · Rôle : Diagramme de Gantt · Source : projectforge-business/src/main/java/org/projectforge/business/gantt/ExportMSProject.java 231 lignes · 151 code · 60 commentaires · 20 vides
Utilitaire d'export Excel/CSV pour les données MSProject. Configure les en-têtes de colonnes (i18n), les formatteurs de champs (devise, date) et remplit les lignes à partir des collections de données.

Structure du code

Paquetage : org.projectforge.business.gantt

Classes : ExportMSProject

Méthodes (3) : addTask, setPredecessors, getRelationType

Importations : 15 paquetages

Code source (abrégé)

package org.projectforge.business.gantt;

import net.sf.mpxj.*;
import net.sf.mpxj.mpx.MPXWriter;
import net.sf.mpxj.mspdi.MSPDIWriter;
import net.sf.mpxj.writer.ProjectWriter;
import org.projectforge.framework.calendar.Holidays;
import org.projectforge.framework.time.PFDateTime;
import org.projectforge.framework.time.PFDayUtils;

import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.Serializable;
import java.math.BigDecimal;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * Utilise l'implémentation de http://mpxj.sourceforge.net/, distribuée sous les termes de la GNU LGPL.
 *
 * @author Kai Reinhard (k.reinhard@micromata.de)
 */
public class ExportMSProject {
  private static final org.slf4j.Logger log = org.slf4j.LoggerFactory.getLogger(ExportMSProject.class);

  public static byte[] exportXml(final GanttChart ganttChart) {
    return export(new MSPDIWriter(), ganttChart);
  }

  public static byte[] exportMpx(final GanttChart ganttChart) {
    return export(new MPXWriter(), ganttChart);
  }

  private static byte[] export(final ProjectWriter result, final GanttChart ganttChart) {
    final ProjectFile file = new ProjectFile();

    //
    // Configure le fichier pour générer automatiquement les identifiants des tâches.
    //
    file.setAutoTaskID(true);
    file.setAutoTaskUniqueID(true);

    //
    // Configure le fichier pour générer automatiquement les identifiants des ressources.
    //
    file.setAutoResourceID(true);
    file.setAutoResourceUniqueID(true);

    //
    // Configure le fichier pour générer automatiquement les niveaux hiérarchiques
    // et les numéros hiérarchiques.
    //
    file.setAutoOutlineLevel(true);
    file.setAutoOutlineNumber(true);

    //
    // Configure le fichier pour générer automatiquement les étiquettes WBS
    //
    file.setAutoWBS(true);

    //
    // Configure le fichier pour générer automatiquement les identifiants des calendriers
    // (pas strictement nécessaire ici, mais requis pour générer des fichiers MSPDI)
    //
    file.setAutoCalendarUniqueID(true);

    //
    // Récupère l'en-tête du projet et définit la date de début. Notez que Microsoft
    // Project semble recaler toutes les dates de tâches par rapport à cette date, donc cette
    // date doit correspondre à la date de début de la tâche la plus ancienne pour que vous voyiez
    // les résultats attendus. Si cette valeur n'est pas définie, elle prendra par défaut la
    // date d'aujourd'hui.
    //
    ganttChart.recalculate();
    final ProjectHeader header = file.getProjectHeader();
    header.setStartDate(PFDayUtils.convertToUtilDate(ganttChart.getCalculatedStartDate()));

    //
    // Ajoute un calendrier par défaut appelé "Standard"
    //
    final ProjectCalendar calendar = file.addDefaultBaseCalendar();
    calendar.setWorkingDay(Day.SATURDAY, false);
    calendar.setWorkingDay(Day.SUNDAY, false);
    PFDateTime dt = PFDateTime.from(ganttChart.getCalculatedStartDate()); // non null
    for (int i = 0; i < 3000; i++) { // Protection contre les boucles infinies (paranoïa)
      dt = dt.plusDays(1);
      Holidays holidays = Holidays.getInstance();
      if (!holidays.isWorkingDay(dt.getDateTime()) && holidays.isHoliday(dt) && !dt.isWeekend()) {
        // Ajoute ce jour férié au calendrier :
        final Date date = dt.getSqlDate();
        calendar.addCalendarException(date, date);
        if (log.isDebugEnabled()) {
          log.debug("Ajout du jour férié : " + date);
        }
      }
      PFDateTime dtEnd = PFDateTime.from(ganttChart.getCalculatedEndDate()); // non null
      if (!dt.isBefore(dtEnd)) {
        break;
      }
    }

    final List<GanttTask> children = ganttChart.getRootNode().getChildren();
    if (children != null) {
      final Map<Serializable, Task> taskMap = new HashMap<>();
      for (final GanttTask child : children) {
        addTask(file, taskMap, null, child);
      }
      for (final GanttTask child : children) {
        setPredecessors(taskMap, child);
      }
    }

    //
    // Écrit le fichier
    //
    final ByteArrayOutputStream ba = new ByteArrayOutputStream();
    try {
// ... (tronqué, total 209 lignes)

Historique Git

868d6abb7 2025 -> 2026
63081666f En-têtes des fichiers source : 2024 -> 2025.
b6092df09 Copyright 2023 -> 2024
ab45d51fa Copyright 2001-2022 -> 2001-2023.
5f7ef41b8 Copyright 2021 -> 2022