Partager via


Obtenir le contenu d’un composant de document à partir d’un package

Cette rubrique montre comment utiliser les classes du Kit de développement logiciel (SDK) Open XML pour Office afin de récupérer le contenu d’un composant de document dans un document Wordprocessing par programmation.


Packages et composants Document

Un document Open XML est stocké sous forme de package, dont le format est défini par la norme ISO/IEC 29500. Le package peut contenir plusieurs parties avec des relations entre elles. La relation entre les parties détermine la catégorie du document. Un document peut être défini comme un document de traitement de texte si son élément de relation de package contient une relation avec une partie principale de document. Si son élément de relation de package contient une relation avec une partie de présentation, il peut être défini comme un document de présentation. Si son élément de relation de package contient une relation avec une partie de classeur, il est défini en tant que feuille de calcul. Dans cette rubrique, vous utiliserez un package de documents de traitement de texte.


Obtention d’un objet WordprocessingDocument

Le code commence par l’ouverture d’un fichier de package en passant un nom de fichier à l’une des méthodes surchargées Open (méthode Visual Basic .NET Shared ou méthode statique C#) de la WordprocessingDocument classe qui prend une chaîne et une valeur booléenne qui spécifie si le fichier doit être ouvert en mode lecture/écriture ou non. Dans ce cas, la valeur false booléenne spécifie que le fichier doit être ouvert en mode lecture seule pour éviter les modifications accidentelles.

using (WordprocessingDocument wordDoc = WordprocessingDocument.Open(document, false))

Avec v3.0.0+ la Close() méthode a été supprimée au profit de l’instruction using. Il garantit que la Dispose() méthode est automatiquement appelée lorsque l’accolade fermante est atteinte. Le bloc qui suit l’instruction using établit une étendue pour l’objet créé ou nommé dans l’instruction using. Étant donné que la WordprocessingDocument classe du Kit de développement logiciel (SDK) Open XML enregistre et ferme automatiquement l’objet dans le cadre de son IDisposable implémentation, et que Dispose() est appelée automatiquement lorsque vous quittez le bloc, vous n’avez pas à appeler Save() explicitement ou Dispose() tant que vous utilisez une using instruction.


Structure d’un document WordProcessingML

La structure de base d’un WordProcessingML document se compose des document éléments et body , suivis d’un ou plusieurs éléments de niveau bloc tels que p, qui représente un paragraphe. Un paragraphe contient un ou plusieurs r éléments. l’acronyme r de run, qui est une région de texte avec un ensemble commun de propriétés, telles que la mise en forme. Une exécution contient un ou plusieurs t éléments. L’élément t contient une plage de texte. L’exemple de code suivant montre le WordprocessingML balisage d’un document qui contient le texte « Exemple de texte ».

    <w:document xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main">
      <w:body>
        <w:p>
          <w:r>
            <w:t>Example text.</w:t>
          </w:r>
        </w:p>
      </w:body>
    </w:document>

À l’aide du Kit de développement logiciel (SDK) Open XML, vous pouvez créer une structure de document et du contenu à l’aide de classes fortement typées qui correspondent à WordprocessingML des éléments. Vous trouverez ces classes dans l’espace de noms . Le tableau suivant répertorie les noms de classes des classes qui correspondent aux documentéléments , body, p, ret t .

Élément WordprocessingML Classe du Kit de développement logiciel (SDK) Open XML Description
<document/> Document Élément racine de la partie principale du document.
<body/> Body Conteneur des structures de niveau bloc, telles que paragraphs, tables, annotations et autres structures décrites dans la spécification ISO/IEC 29500.
<p/> Paragraph Paragraphe.
<r/> Run Exécution.
<t/> Text Plage de texte.

Pour plus d’informations sur la structure globale des parties et éléments d’un document WordprocessingML, consultez Structure d’un document WordprocessingML.


Élément comments

Dans cette rubrique de procédure, vous allez travailler avec des commentaires. Par conséquent, il est utile de vous familiariser avec la structure de l’élément <comments/> . Les informations suivantes de la spécification ISO/IEC 29500 peuvent être utiles lors de l’utilisation de cet élément.

Cet élément spécifie tous les commentaires définis dans le document actuel. Il s’agit de l’élément racine de la partie commentaires d’un document WordprocessingML. Considérez le fragment WordprocessingML suivant pour le contenu d’un composant de commentaires dans un document WordprocessingML :

    <w:comments>
      <w:comment … >
        …
      </w:comment>
    </w:comments>

L’élément comments contient le commentaire spécifié par ce document dans cet exemple.

© ISO/IEC 29500 : 2016

Le fragment de schéma XML suivant définit le contenu de cet élément.

    <complexType name="CT_Comments">
       <sequence>
           <element name="comment" type="CT_Comment" minOccurs="0" maxOccurs="unbounded"/>
       </sequence>
    </complexType>

Fonctionnement de l’exemple de code

Une fois que vous avez ouvert le fichier source pour la lecture, vous créez un mainPart objet en instanciant le MainDocumentPart. Vous pouvez ensuite créer une référence à la WordprocessingCommentsPart partie du document.

static string GetCommentsFromDocument(string document)
{
    string? comments = null;

    using (WordprocessingDocument wordDoc = WordprocessingDocument.Open(document, false))
    {
        if (wordDoc is null)
        {
            throw new ArgumentNullException(nameof(wordDoc));
        }

        MainDocumentPart mainPart = wordDoc.MainDocumentPart ?? wordDoc.AddMainDocumentPart();
        WordprocessingCommentsPart WordprocessingCommentsPart = mainPart.WordprocessingCommentsPart ?? mainPart.AddNewPart<WordprocessingCommentsPart>();

Vous pouvez ensuite utiliser un StreamReader objet pour lire le contenu de la WordprocessingCommentsPart partie du document et retourner son contenu.

    using (StreamReader streamReader = new StreamReader(WordprocessingCommentsPart.GetStream()))
    {
        comments = streamReader.ReadToEnd();
    }
}

return comments;

Exemple de code

Le code suivant récupère le contenu d’un WordprocessingCommentsPart composant contenu dans un WordProcessing package de document. Vous pouvez exécuter le programme en appelant la GetCommentsFromDocument méthode comme indiqué dans l’exemple suivant.

string document = args[0];
GetCommentsFromDocument(document);

Voici l'exemple de code complet en C# et Visual Basic.

static string GetCommentsFromDocument(string document)
{
    string? comments = null;

    using (WordprocessingDocument wordDoc = WordprocessingDocument.Open(document, false))
    {
        if (wordDoc is null)
        {
            throw new ArgumentNullException(nameof(wordDoc));
        }

        MainDocumentPart mainPart = wordDoc.MainDocumentPart ?? wordDoc.AddMainDocumentPart();
        WordprocessingCommentsPart WordprocessingCommentsPart = mainPart.WordprocessingCommentsPart ?? mainPart.AddNewPart<WordprocessingCommentsPart>();

        using (StreamReader streamReader = new StreamReader(WordprocessingCommentsPart.GetStream()))
        {
            comments = streamReader.ReadToEnd();
        }
    }

    return comments;
}

Voir aussi

Informations de référence sur la bibliothèque de classes du Kit de développement logiciel (SDK) Open XML