Extraire et enregistrer une pièce jointe
Obtenir toutes les pièces jointes
Avec Aspose.PDF, il est possible d’obtenir toutes les pièces jointes d’un document PDF. Cela est utile soit lorsque vous souhaitez enregistrer les documents séparément du PDF, soit si vous devez retirer un PDF de ses pièces jointes.
Pour obtenir toutes les pièces jointes d’un fichier PDF :
Parcourez la collection EmbeddedFiles de l’objet Document . La collection EmbeddedFiles contient toutes les pièces jointes. Chaque élément de cette collection représente un objet FileSpecification . Chaque itération de la boucle foreach à travers la collection EmbeddedFiles renvoie un objet FileSpecification .
Une fois l’objet disponible, récupérez soit toutes les propriétés du fichier joint, soit le fichier lui-même.
Les extraits de code suivants montrent comment obtenir toutes les pièces jointes d’un document PDF.
L’extrait de code suivant fonctionne également avec la bibliothèque Aspose.PDF.Drawing .
.NET Core 3.1
Copy
private static void GetAllAttachments ( )
{
var dataDir = RunExamples . GetDataDir_AsposePdf_Attachments ();
using ( var document = new Aspose . Pdf . Document ( dataDir + "GetAlltheAttachments.pdf" ))
{
Aspose . Pdf . EmbeddedFileCollection embeddedFiles = document . EmbeddedFiles ;
Console . WriteLine ( "Total files : {0}" , embeddedFiles . Count );
int count = 1 ;
foreach ( Aspose . Pdf . FileSpecification fileSpecification in embeddedFiles )
{
Console . WriteLine ( "Name: {0}" , fileSpecification . Name );
Console . WriteLine ( "Description: {0}" ,
fileSpecification . Description );
Console . WriteLine ( "Mime Type: {0}" , fileSpecification . MIMEType );
if ( fileSpecification . Params != null )
{
Console . WriteLine ( "CheckSum: {0}" ,
fileSpecification . Params . CheckSum );
Console . WriteLine ( "Creation Date: {0}" ,
fileSpecification . Params . CreationDate );
Console . WriteLine ( "Modification Date: {0}" ,
fileSpecification . Params . ModDate );
Console . WriteLine ( "Size: {0}" , fileSpecification . Params . Size );
}
var fileContent = new byte [ fileSpecification . Contents . Length ];
fileSpecification . Contents . Read ( fileContent , 0 , fileContent . Length );
using ( var fileStream = new FileStream ( dataDir + count + "_out" + ".txt" , FileMode . Create ))
{
fileStream . Write ( fileContent , 0 , fileContent . Length );
}
count += 1 ;
}
}
}
.NET 8
Copy
private static void GetAllAttachments ( )
{
var dataDir = RunExamples . GetDataDir_AsposePdf_Attachments ();
using var document = new Aspose . Pdf . Document ( dataDir + "GetAlltheAttachments.pdf" );
Aspose . Pdf . EmbeddedFileCollection embeddedFiles = document . EmbeddedFiles ;
Console . WriteLine ( "Total files : {0}" , embeddedFiles . Count );
int count = 1 ;
foreach ( Aspose . Pdf . FileSpecification fileSpecification in embeddedFiles )
{
Console . WriteLine ( "Name: {0}" , fileSpecification . Name );
Console . WriteLine ( "Description: {0}" ,
fileSpecification . Description );
Console . WriteLine ( "Mime Type: {0}" , fileSpecification . MIMEType );
if ( fileSpecification . Params != null )
{
Console . WriteLine ( "CheckSum: {0}" ,
fileSpecification . Params . CheckSum );
Console . WriteLine ( "Creation Date: {0}" ,
fileSpecification . Params . CreationDate );
Console . WriteLine ( "Modification Date: {0}" ,
fileSpecification . Params . ModDate );
Console . WriteLine ( "Size: {0}" , fileSpecification . Params . Size );
}
var fileContent = new byte [ fileSpecification . Contents . Length ];
fileSpecification . Contents . Read ( fileContent , 0 , fileContent . Length );
using var fileStream = new FileStream ( dataDir + count + "_out" + ".txt" , FileMode . Create );
fileStream . Write ( fileContent , 0 , fileContent . Length );
count += 1 ;
}
}
Obtenir une pièce jointe individuelle
Pour obtenir une pièce jointe individuelle, nous pouvons spécifier l’index de la pièce jointe dans l’objet EmbeddedFiles
de l’instance Document. Veuillez essayer d’utiliser l’extrait de code suivant.
.NET Core 3.1
Copy
private static void GetIndividualAttachment ( )
{
var dataDir = RunExamples . GetDataDir_AsposePdf_Attachments ();
using ( var document = new Aspose . Pdf . Document ( dataDir + "GetIndividualAttachment.pdf" ))
{
Aspose . Pdf . FileSpecification fileSpecification = document . EmbeddedFiles [ 1 ];
Console . WriteLine ( "Name: {0}" , fileSpecification . Name );
Console . WriteLine ( "Description: {0}" , fileSpecification . Description );
Console . WriteLine ( "Mime Type: {0}" , fileSpecification . MIMEType );
if ( fileSpecification . Params != null )
{
Console . WriteLine ( "CheckSum: {0}" ,
fileSpecification . Params . CheckSum );
Console . WriteLine ( "Creation Date: {0}" ,
fileSpecification . Params . CreationDate );
Console . WriteLine ( "Modification Date: {0}" ,
fileSpecification . Params . ModDate );
Console . WriteLine ( "Size: {0}" , fileSpecification . Params . Size );
}
var fileContent = new byte [ fileSpecification . Contents . Length ];
fileSpecification . Contents . Read ( fileContent , 0 , fileContent . Length );
using ( var fileStream = new FileStream ( dataDir + "test_out" + ".txt" , FileMode . Create ))
{
fileStream . Write ( fileContent , 0 , fileContent . Length );
}
}
}
.NET 8
Copy
private static void GetIndividualAttachment ( )
{
var dataDir = RunExamples . GetDataDir_AsposePdf_Attachments ();
using var document = new Aspose . Pdf . Document ( dataDir + "GetIndividualAttachment.pdf" );
Aspose . Pdf . FileSpecification fileSpecification = document . EmbeddedFiles [ 1 ];
Console . WriteLine ( "Name: {0}" , fileSpecification . Name );
Console . WriteLine ( "Description: {0}" , fileSpecification . Description );
Console . WriteLine ( "Mime Type: {0}" , fileSpecification . MIMEType );
if ( fileSpecification . Params != null )
{
Console . WriteLine ( "CheckSum: {0}" ,
fileSpecification . Params . CheckSum );
Console . WriteLine ( "Creation Date: {0}" ,
fileSpecification . Params . CreationDate );
Console . WriteLine ( "Modification Date: {0}" ,
fileSpecification . Params . ModDate );
Console . WriteLine ( "Size: {0}" , fileSpecification . Params . Size );
}
var fileContent = new byte [ fileSpecification . Contents . Length ];
fileSpecification . Contents . Read ( fileContent , 0 , fileContent . Length );
using var fileStream = new FileStream ( dataDir + "test_out" + ".txt" , FileMode . Create );
fileStream . Write ( fileContent , 0 , fileContent . Length );
}
Obtenir les pièces jointes contenues dans des objets FileAttachmentAnnotation
En plus de la collection EmbeddedFiles de l’objet Document, les pièces jointes peuvent également être contenues dans des objets FileAttachmentAnnotation. Ci-dessous se trouve le code pour visualiser le nombre et les détails de telles pièces jointes.