EN · DE · RU · FR · ES

#454: ExportMSProject.java

projectforge-business/src/main/java/org/projectforge/business/gantt/ExportMSProject.java Tipo: Java · Rol: Diagrama de Gantt · Fuente: projectforge-business/src/main/java/org/projectforge/business/gantt/ExportMSProject.java 231 líneas · 151 código · 60 comentarios · 20 en blanco
Utilidad de exportación Excel/CSV para datos de MSProject. Configura encabezados de columna (i18n), formateadores de campo (moneda, fecha) y llena filas desde colecciones de datos.

Estructura del código

Paquete: org.projectforge.business.gantt

Clases: ExportMSProject

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

Importaciones: 15 paquetes

Código fuente (resumido)

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;

/**
 * Utiliza la implementación de http://mpxj.sourceforge.net/, distribuida bajo los términos de 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();

    //
    // Configura el archivo para generar automáticamente identificadores de tareas.
    //
    file.setAutoTaskID(true);
    file.setAutoTaskUniqueID(true);

    //
    // Configura el archivo para generar automáticamente identificadores de recursos.
    //
    file.setAutoResourceID(true);
    file.setAutoResourceUniqueID(true);

    //
    // Configura el archivo para generar automáticamente niveles de esquema
    // y números de esquema.
    //
    file.setAutoOutlineLevel(true);
    file.setAutoOutlineNumber(true);

    //
    // Configura el archivo para generar automáticamente etiquetas WBS
    //
    file.setAutoWBS(true);

    //
    // Configura el archivo para generar automáticamente identificadores de calendarios
    // (no estrictamente necesario aquí, pero requerido si se generan archivos MSPDI)
    //
    file.setAutoCalendarUniqueID(true);

    //
    // Obtiene el encabezado del proyecto y establece la fecha de inicio. Nota: Microsoft
    // Project parece restablecer todas las fechas de tareas en relación con esta fecha, por lo que
    // esta fecha debe coincidir con la fecha de inicio de la tarea más temprana para ver
    // los resultados esperados. Si este valor no se establece, se usará la fecha de hoy.
    //
    ganttChart.recalculate();
    final ProjectHeader header = file.getProjectHeader();
    header.setStartDate(PFDayUtils.convertToUtilDate(ganttChart.getCalculatedStartDate()));

    //
    // Agrega un calendario predeterminado llamado "Estándar"
    //
    final ProjectCalendar calendar = file.addDefaultBaseCalendar();
    calendar.setWorkingDay(Day.SATURDAY, false);
    calendar.setWorkingDay(Day.SUNDAY, false);
    PFDateTime dt = PFDateTime.from(ganttChart.getCalculatedStartDate()); // no nulo
    for (int i = 0; i < 3000; i++) { // Protección contra bucle infinito (paranoia)
      dt = dt.plusDays(1);
      Holidays holidays = Holidays.getInstance();
      if (!holidays.isWorkingDay(dt.getDateTime()) && holidays.isHoliday(dt) && !dt.isWeekend()) {
        // Agrega este día festivo al calendario:
        final Date date = dt.getSqlDate();
        calendar.addCalendarException(date, date);
        if (log.isDebugEnabled()) {
          log.debug("Agregar día festivo: " + date);
        }
      }
      PFDateTime dtEnd = PFDateTime.from(ganttChart.getCalculatedEndDate()); // no nulo
      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);
      }
    }

    //
    // Escribe el archivo
    //
    final ByteArrayOutputStream ba = new ByteArrayOutputStream();
    try {
// ... (truncado, 209 líneas en total)

Historial de Git

868d6abb7 2025 -> 2026
63081666f Encabezados de archivos fuente: 2024 -> 2025.
b6092df09 Copyright 2023 -> 2024
ab45d51fa Copyright 2001-2022 -> 2001-2023.
5f7ef41b8 Copyright 2021 -> 2022