EN · DE · RU · FR · ES

#454: ExportMSProject.java

projectforge-business/src/main/java/org/projectforge/business/gantt/ExportMSProject.java Typ: Java · Rolle: Gantt-Diagramm · Quelle: projectforge-business/src/main/java/org/projectforge/business/gantt/ExportMSProject.java 231 Zeilen · 151 Code · 60 Kommentare · 20 leer
Excel/CSV-Export-Dienstprogramm für MSProject-Daten. Konfiguriert Spaltenüberschriften (i18n), Feldformatierer (Währung, Datum) und befüllt Zeilen aus Datensammlungen.

Codestruktur

Paket: org.projectforge.business.gantt

Klassen: ExportMSProject

Methoden (3): addTask, setPredecessors, getRelationType

Importe: 15 Pakete

Quellcode (gekürzt)

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;

/**
 * Verwendet die Implementierung von http://mpxj.sourceforge.net/, die unter den Bedingungen der GNU LGPL vertrieben wird.
 *
 * @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();

    //
    // Konfiguriert die Datei, um automatisch Kennungen für Aufgaben zu generieren.
    //
    file.setAutoTaskID(true);
    file.setAutoTaskUniqueID(true);

    //
    // Konfiguriert die Datei, um automatisch Kennungen für Ressourcen zu generieren.
    //
    file.setAutoResourceID(true);
    file.setAutoResourceUniqueID(true);

    //
    // Konfiguriert die Datei, um automatisch Gliederungsebenen
    // und Gliederungsnummern zu generieren.
    //
    file.setAutoOutlineLevel(true);
    file.setAutoOutlineNumber(true);

    //
    // Konfiguriert die Datei, um automatisch WBS-Bezeichnungen zu generieren
    //
    file.setAutoWBS(true);

    //
    // Konfiguriert die Datei, um automatisch Kennungen für Kalender zu generieren
    // (hier nicht unbedingt erforderlich, aber notwendig, wenn MSPDI-Dateien generiert werden)
    //
    file.setAutoCalendarUniqueID(true);

    //
    // Ruft den Projektkopf ab und setzt das Startdatum. Hinweis: Microsoft
    // Project scheint alle Aufgabendaten relativ zu diesem Datum zurückzusetzen, daher muss dieses
    // Datum mit dem Startdatum der frühesten Aufgabe übereinstimmen, um die erwarteten
    // Ergebnisse zu sehen. Wenn dieser Wert nicht gesetzt ist, wird standardmäßig das
    // heutige Datum verwendet.
    //
    ganttChart.recalculate();
    final ProjectHeader header = file.getProjectHeader();
    header.setStartDate(PFDayUtils.convertToUtilDate(ganttChart.getCalculatedStartDate()));

    //
    // Fügt einen Standardkalender namens "Standard" hinzu
    //
    final ProjectCalendar calendar = file.addDefaultBaseCalendar();
    calendar.setWorkingDay(Day.SATURDAY, false);
    calendar.setWorkingDay(Day.SUNDAY, false);
    PFDateTime dt = PFDateTime.from(ganttChart.getCalculatedStartDate()); // nicht null
    for (int i = 0; i < 3000; i++) { // Endlosschleifenschutz (Paranoia)
      dt = dt.plusDays(1);
      Holidays holidays = Holidays.getInstance();
      if (!holidays.isWorkingDay(dt.getDateTime()) && holidays.isHoliday(dt) && !dt.isWeekend()) {
        // Diesen Feiertag zum Kalender hinzufügen:
        final Date date = dt.getSqlDate();
        calendar.addCalendarException(date, date);
        if (log.isDebugEnabled()) {
          log.debug("Feiertag hinzugefügt: " + date);
        }
      }
      PFDateTime dtEnd = PFDateTime.from(ganttChart.getCalculatedEndDate()); // nicht 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);
      }
    }

    //
    // Schreibt die Datei
    //
    final ByteArrayOutputStream ba = new ByteArrayOutputStream();
    try {
// ... (gekürzt, insgesamt 209 Zeilen)

Git-Verlauf

868d6abb7 2025 -> 2026
63081666f Quellcode-Dateiköpfe: 2024 -> 2025.
b6092df09 Copyright 2023 -> 2024
ab45d51fa Copyright 2001-2022 -> 2001-2023.
5f7ef41b8 Copyright 2021 -> 2022