Jak zapisywać prezentacje w Java

Jak zapisywać prezentacje w Java

Aspose.Slides FOSS for Java saves presentations exclusively to .pptx format przy użyciu prs.save(path, SaveFormat.PPTX). Ten przewodnik opisuje prawidłowy wzorzec zapisu, zapisywanie do innej ścieżki oraz typowe błędy związane z zapisem.

Przewodnik krok po kroku

Krok 1: Dodaj zależność Maven

<dependency>
  <groupId>org.aspose.slides.foss</groupId>
  <artifactId>aspose-slides-foss</artifactId>
  <version>1.0.0</version>
</dependency>

Krok 2: Otwórz lub utwórz prezentację

Zawsze używaj try-with-resources. Wywołanie zapisu musi znajdować się wewnątrz bloku try.

import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.ISlide;
import org.aspose.slides.foss.IAutoShape;
import org.aspose.slides.foss.ShapeType;
import org.aspose.slides.foss.export.SaveFormat;

// Create new
try (Presentation prs = new Presentation()) {
    prs.save("new.pptx", SaveFormat.PPTX);
}

// Open existing
try (Presentation prs = new Presentation("input.pptx")) {
    prs.save("output.pptx", SaveFormat.PPTX);
}

Krok 3: Zapisz po wszystkich modyfikacjach

Umieść save() wywołanie jako ostatnie polecenie wewnątrz bloku try, po zakończeniu wszystkich modyfikacji.

import org.aspose.slides.foss.Presentation;
import org.aspose.slides.foss.ISlide;
import org.aspose.slides.foss.IAutoShape;
import org.aspose.slides.foss.ShapeType;
import org.aspose.slides.foss.export.SaveFormat;

try (Presentation prs = new Presentation()) {
    ISlide slide = prs.getSlides().get(0);
    IAutoShape shape = slide.getShapes().addAutoShape(
        ShapeType.RECTANGLE, 50, 50, 300, 100
    );
    shape.addTextFrame("Hello, World!");
    prs.save("output.pptx", SaveFormat.PPTX);
}

Krok 4: Zapisz do innej ścieżki

Podaj inną ścieżkę wyjściową, aby utworzyć nowy plik bez modyfikacji oryginału:

try (Presentation prs = new Presentation("template.pptx")) {
    // modify ...
    prs.save("customized.pptx", SaveFormat.PPTX);
}

Ten template.pptx plik nie jest modyfikowany; customized.pptx jest tworzony (lub nadpisywany, jeśli już istnieje).


Krok 5: Zweryfikuj wynik

Po zakończeniu bloku try plik jest kompletny i zamknięty. Sprawdź, czy istnieje:

import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;

Path output = Paths.get("output.pptx");
System.out.println("Saved: " + Files.exists(output)
    + ", size: " + Files.size(output) + " bytes");

Obsługiwany format zapisu

FormatWartość wyliczeniaObsługiwane
PPTX (Office Open XML)SaveFormat.PPTXTak
PDFN/ANie
HTMLN/ANie
SVGN/ANie
PNG / JPEGN/ANie
ODP (OpenDocument)N/ANie

Tylko PPTX jest w pełni obsługiwany. Przekazywanie jakiegokolwiek innego SaveFormat wartość do prs.save(path, format) cicho zapisuje jako PPTX — nie jest zgłaszany żaden wyjątek, a argument formatu jest ignorowany. UnsupportedOperationException jest zgłaszany tylko przez prs.save(ISaveOptions options), nie przez przeciążenia oparte na formacie.


Typowe problemy i rozwiązania

java.io.IOException: Permission denied

Plik wyjściowy jest otwarty w innej aplikacji (np. PowerPoint ma otwarty plik). Zamknij plik w innych aplikacjach przed zapisem.

Plik został utworzony, ale wydaje się pusty lub uszkodzony

Upewnij się prs.save() jest wywoływane wewnątrz bloku try, a nie po nim. Po zakończeniu bloku try-with-resources, Presentation obiekt jest usuwany, a kolejne wywołania zakończą się niepowodzeniem.

UnsupportedOperationException przy zapisywaniu

To występuje przy użyciu prs.save(ISaveOptions options) — the ISaveOptions-based overload nie jest zaimplementowane. Uwaga: przekazywanie nie‑PPTX SaveFormat do prs.save(path, format) wykonuje nie rzucić ten wyjątek; cicho zapisuje jako PPTX.


Najczęściej zadawane pytania

Czy mogę zapisać do tego samego pliku, który otworzyłem?

Tak. Zapis do tej samej ścieżki nadpisuje oryginalny plik:

try (Presentation prs = new Presentation("deck.pptx")) {
    // modify ...
    prs.save("deck.pptx", SaveFormat.PPTX);  // overwrites original
}

Czy mogę zapisać do OutputStream?

Tak. Ten save() metoda przyjmuje OutputStream:

import java.io.FileOutputStream;

try (Presentation prs = new Presentation();
     FileOutputStream fos = new FileOutputStream("output.pptx")) {
    prs.save(fos, SaveFormat.PPTX);
}

Czy zapis zachowuje zawartość, której nie zmodyfikowałem?

Tak. Nieznane części XML z oryginalnego pliku są zachowywane wprost. Biblioteka serializuje tylko te części modelu dokumentu, które rozumie, i przepuszcza wszelki XML, którego nie rozpoznaje.


Zobacz także

 Polski