[Open XML] Quelques exemples Word pour la CTP 2 du SDK Open XML
Après cette release qui corrige un certain nombre de bugs et apporte quelques petites nouveautés, et même si les changements ne sont pas significatifs par rapport à la précédent CTP (et en attendant la future version 2.0 du SDK), la CTP 2 du SDK Open XML permet d'ore et déjà de pouvoir faire quelques applications orientées documents en quelques lignes de codes.
Génération d'un nouveau document Word
Comme toute CTP, cette version n'est pas exempte de problèmes et autres améliorations qui seront adressées dans le futur. Je ne vais pas vous énumérer tout ce que très bien dit dans les fichiers attachés au SDK sauf, car on m'a posé la question, que les fichiers .docx vides (0 Ko) créés depuis le menu shell de Windows ne s'ouvriront pas avec le SDK (comme le permet Word 2007).
En revanche, rien de bien gênant puisque voici la façon de créer un fichier Word en quelques lignes de code avec le SDK Open XML en partant de rien :
public static void CreateNewWordDocument(string document)
{
using (WordprocessingDocument wordDoc = WordprocessingDocument.Create(document, WordprocessingDocumentType.Document))
{
MainDocumentPart mainPart = wordDoc.AddMainDocumentPart();
SetMainDocumentContent(mainPart);
}
}
public static void SetMainDocumentContent(MainDocumentPart part)
{
const string docXml =
@"<?xml version=""1.0"" encoding=""UTF-8"" standalone=""yes""?>
<w:document xmlns:w=""http://schemas.openxmlformats.org/wordprocessingml/2006/main"">
<w:body>
<w:p>
<w:r>
<w:t>Hello world!</w:t>
</w:r>
</w:p>
</w:body>
</w:document>";
using (Stream stream = part.GetStream())
{
byte[] buf = (new UTF8Encoding()).GetBytes(docXml);
stream.Write(buf, 0, buf.Length);
}
}
static void Main(string[] args)
{
CreateNewWordDocument("MonDoc.docx");
}
Plutôt simple non ? Vous ne trouvez pas que l'on a progressé ces dernières années pour pouvoir générer des documents Word ?
Remplacement d'une partie de Custom XML
Voici également comment remplacer le contenu d'une partie CustomXML (très utile comme montré dans ce post) par un autre contenu XML qui pourra changer le contenu final de votre document :
using (WordprocessingDocument wordDoc = WordprocessingDocument.Open(fileName, true))
{
MainDocumentPart mainPart = wordDoc.MainDocumentPart;
// Supprime la partie existante
mainPart.DeletePart("rId1");
// Ajoute une nouvelle partie CustomXML
CustomXmlPart customXmlPart = mainPart.AddNewPart<CustomXmlPart>();
// Copie le nouveau contenu XML dans la partie Custom XML
using (StreamWriter ts = new StreamWriter(customXmlPart.GetStream()))
{
string xmlContent = File.ReadAllText(customXML);
ts.Write(xmlContent);
}
}
Prochain post avec quelques exemples pour Excel et PowerPoint comme beaucoup me le demande.
Les exemples ci-dessus sont volontairement très simples afin de vous présenter le SDK Open XML. Néanmoins, vous pouvez déjà en faire beaucoup avec le SDK dans son état actuel et en quelques lignes de code - c'est là tout son intérêt - même si les plus experts d'entre vous seront parfois obligé d'avoir recours à des workaround pour accéder à certaines données tel que des ID ou autre (normalement en cours de correction).
N'oubliez pas le portail Open XML à cette adresse pour trouver de nombreuses ressources : http://msdn2.microsoft.com/en-us/office/aa905545.aspx
Le posters Open XML et stickers disponibles pour les WygDays 2008 (le 22 Mai 2008)
Après mon passage à Redmond lors du MVP Summit, j'ai pu récupéré quelques posters et stickers (un grand merci aux équipes de dev pour cela) que les visiteurs pourront récupérer lors du WygDay :

Ce post vous a plu ? Ajoutez le dans vos favoris pour ne pas perdre de temps à le retrouver le jour où vous en aurez besoin :