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. |