Wykrywanie formatu pliku i sprawdzanie kompatybilności formatu

Czasami konieczne jest określenie formatu dokumentu przed otwarciem, ponieważ rozszerzenie pliku nie gwarantuje, że zawartość pliku jest odpowiednia. Na przykład wiadomo, że Crystal Reports często wysyła dokumenty w formacie RTF, ale daje im rozszerzenie .doc.

Aspose.Words zapewnia możliwość uzyskania informacji o typie pliku w celu uniknięcia wyjątku, jeśli nie jesteś pewien, jaka jest rzeczywista zawartość pliku.

Wykrywanie formatu pliku bez wyjątku

Kiedy masz do czynienia z wieloma dokumentami w różnych formatach plików, może być konieczne oddzielenie tych plików, które mogą być przetwarzane przez Aspose.Words od tych, którzy nie mogą. Możesz również chcieć wiedzieć, dlaczego niektóre dokumenty nie mogą być przetwarzane.

Jeśli próbujesz załadować plik do Document obiekt i Aspose.Words nie może rozpoznać formatu pliku lub format nie jest obsługiwany, Aspose.Words Rzuci wyjątek. Można złapać te wyjątki i analizować je, ale Aspose.Words zapewnia również DetectFileFormat metoda, która pozwala nam szybko określić format pliku bez wczytywania dokumentu z ewentualnymi wyjątkami. Ta metoda zwraca a FileFormatInfo obiekt, który zawiera wykryte informacje o typie pliku.

Sprawdź kompatybilność formatu plików

Możemy sprawdzić kompatybilność formatów wszystkich plików w wybranym folderze i sortować je w formacie do odpowiednich podfolderów.

Ponieważ mamy do czynienia z zawartością w folderze, pierwszą rzeczą, którą musimy zrobić jest zebranie wszystkich plików w tym folderze za pomocą GetFiles Metoda Directory klasa (z System.IO ).

Poniższy przykład kodu pokazuje jak uzyskać listę wszystkich plików w folderze:

Kiedy wszystkie pliki są zbierane, reszta pracy jest wykonywana przez DetectFileFormat metoda, która sprawdza format pliku.

Poniższy przykład kodu pokazuje, jak iteracować nad zebraną listą plików, sprawdzić format każdego pliku i przenieść każdy plik do odpowiedniego folderu:

Pliki są przenoszone do odpowiednich podfolderów za pomocą Move Metoda File klasa, od tego samego System.IO przestrzeń nazw.

Następujące pliki są używane w powyższym przykładzie. Nazwa pliku jest po lewej stronie, a jej opis po prawej:

Group plików Dokument wejścia Rodzaj
Obsługiwane formaty plików Plik testowy (Doc) .doc Microsoft Word 95 / 6, 0 lub Microsoft Word Dokument 97 - 2003.
Plik testowy (Dot) .dot Microsoft Word 95 / 6, 0 lub Microsoft Word Wzór formularza 97 - 2003.
Plik testowy (Docx) .docx Office Open XML Wordprocessing Dokument ML bez makr.
Plik testowy (Docm) .docm Office Open XML Wordprocessing Dokument ML z makrami.
Plik testowy (Dotx) .dotx Office Open XML Wordprocessing Wzór ML.
Plik testowy (Dotm) .dotm Office Open XML Wordprocessing Szablon ML z makrami.
Plik testowy (XML) .xml Dokument OOXML FlatoPC.
Plik testowy (RTF) .rtf Rich Text Format Document.
Plik testowy (WordML) .xml Microsoft Word 2003 Wordprocessing Dokument ML.
Test File (HTML) .html Dokument HTML.
Plik testowy (MHTML) .mhtml Dokument MHTML (Web Archive).
Plik testowy (ODT) .odt Tekst OpenDocument (OpenOffice Writer).
Plik testowy (Ott) .ott Szablon dokumentu OpenDocument.
Plik testowy (DocPreWord60) .doc Microsoft Word 2.0 dokument.
Zaszyfrowane dokumenty Plik testowy (Enc) .doc Zaszyfrowane Microsoft Word 95 / 6, 0 lub Microsoft Word Dokument 97 - 2003.
Plik testowy (Enc) .docx Szyfrowane Office Open XML Wordprocessing Dokument ML.
Nieobsługiwane formaty plików Test File (JPG). jpg Plik obrazu JPEG.