Può capitare di dover accedere ad un documento di Word da un'applicazione Silverlight e dover effettuare delle personalizzazioni nel documento stesso.
Se l'applicazione viene eseguita in OOB, con Elevated Trusted, è possibile accedere direttamente alle applicazioni Office e ad altre funzionalità.
E' possibile, ad esempio, istanziare un oggetto di tipo Word per lavorare direttamente su documenti di tipo DOC, o DOCX, dalla nostra applicazione.
E' necessario importare alcuni namespace per poter lavorare con questi oggetti:
using System.Windows.Interop; using System.Runtime.Interopservices.Automation;
A questo punto, dal code behind di una Silverlight page possiamo istanziare un oggetto di tipo Word:
dynamic wordDocument = AutomationFactory.CreateObject("Word.Application");
Il problema ora è come pilotare l'oggetto wordDocument appena creato.
Un esempio classico potrebbe essere quello di aprire un documento con degli appositi segnalibri, ricercarli e personalizzare il documento, quindi salvarlo con un altro nome ed inviarlo per email al nostro destinatario.
Per sapere quali metodi l'oggetto creato mette a disposizione può essere utile registrare una macro in direttamente Microsoft Word, che faccia quello appunto di cui abbiamo bisogno, in questo caso cercare un segnalibro e sostituire il codice presente con un nostro testo personalizzato.
La macro registrata si presenta in questo modo:
Sub TrovaBookmarks() Selection.GoTo What:=wdGoToBookmark, Name:="Oggetto" Selection.Find.ClearFormatting With Selection.Find .Text = "Vecchio Testo" .Replacement.Text = "Nuovo Testo" .Forward = True .Wrap = wdFindContinue .Format = False .MatchCase = False .MatchWholeWord = False .MatchWildcards = False .MatchSoundsLike = False .MatchAllWordForms = False End With End Sub
A questo punto è facile convertire il codice VBA in C#, in questo caso ed implementarlo all'interno del nostro codice:
if (App.Current.IsRunningOutOfBrowser && App.Current.HasElevatedPermissions) { dynamic wordDocument = AutomationFactory.CreateObject("Word.Application"); object path = @"C:\" + dialog.File.Name; object paramMissing = Type.Missing; wordDocument.Documents.Open(ref path, ref paramMissing, ref paramMissing, ref paramMissing, ref paramMissing, ref paramMissing, ref paramMissing, ref paramMissing, ref paramMissing, ref paramMissing, ref paramMissing, ref paramMissing, ref paramMissing, ref paramMissing, ref paramMissing, ref paramMissing); object bookmark = -1; object nameBookmark = "oggetto"; wordDocument.Selection.GoTO(bookmark, paramMissing, paramMissing, nameBookmark); wordDocument.Selection.TypeText("NUOVO TESTO"); }
L'oggetto wordDocument è a tutti gli effetti Word, quindi il suo potenziale è limitato solo dalla fantasia nel creare applicazioni che lo sfruttino in tutti i modi possibili.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Utilizzare un numero per gestire la concorrenza ottimistica con SQL Server ed Entity Framework
Garantire la provenienza e l'integrità degli artefatti prodotti su GitHub
Disabilitare le run concorrenti di una pipeline di Azure DevOps
Utilizzare l'espressione if inline in una pipeline di Azure DevOps
Gestione CSS in Blazor con .NET 9
Documentare i servizi REST con Swagger e OpenAPI con .NET 9
Gestire gli accessi con Token su Azure Container Registry
Popolare una classe a partire dal testo, con Semantic Kernel e ASP.NET Core Web API
Effettuare il log delle chiamate a function di GPT in ASP.NET Web API
Utilizzare i variable font nel CSS
Testare l'invio dei messaggi con Event Hubs Data Explorer
Sfruttare gli embedding e la ricerca vettoriale con Azure SQL Database
I più letti di oggi
- Eseguire una chiamata AJAX per inviare dati al server in Angular 2
- Formati per l'impostazione del colore in CSS3
- .NET Conference Italia 2024 - Milano
- Gestione CSS in Blazor con .NET 9
- build 7712 per #wp7 #mango riservata agli sviluppatori, con refresh dei tool su connect. info su http://aspitalia.com/y6
- oggi a partire dalle 16:00, non perdere #connect. tutto sul futuro di #vs, #azure, #aspnet https://aspit.co/azk