Panoramica dei campi

Solitamente un campo, quando inserito in Microsoft Word, contiene già un valore aggiornato. Ad esempio, se il campo è una formula o un numero di pagina, conterrà un valore calcolato corretto per la versione specifica del documento. Ma se hai un’applicazione che genera o modifica un documento con campi (ad esempio combina due documenti o popola con dati), affinché il documento sia utile, tutti i campi dovrebbero idealmente essere aggiornati.

Un campo è costituito da:

fields-aspose-words

  • I nodi iniziale e separatore del campo vengono utilizzati per racchiudere il contenuto che costituisce il codice del campo (normalmente come testo normale)
  • Il separatore di campo e la fine del campo racchiudono il risultato del campo. Questo può essere costituito da vari tipi di contenuto che vanno dalle sequenze di testo ai paragrafi alle tabelle.
  • Alcuni campi potrebbero non avere un separatore, il che significa che l’intero contenuto costituisce il codice del campo.
  • Il codice di campo definisce il comportamento del campo ed è composto dall’identificatore del campo e spesso da altri parametri come il nome del campo e le opzioni.
  • Il risultato del campo contiene la valutazione più recente del campo. Questo valore viene memorizzato nel campo risultato ed è ciò che viene visualizzato all’utente. Alcuni campi potrebbero non avere alcun risultato di campo quindi non verrà visualizzato nulla nel documento. Allo stesso modo, alcuni campi potrebbero non essere ancora aggiornati, pertanto non avranno risultati di campo.

Ecco una visualizzazione di come un campo viene archiviato in Aspose.Words utilizzando l’esempio “DocumentExplorer” che può essere trovato su Github.

document-explorer-aspose-words

Aspose.Words è una libreria di classi progettata per l’elaborazione lato server di documenti Microsoft Word e supporta i campi nei seguenti modi:

  • Tutti i campi in un documento vengono conservati durante l’apertura/salvataggio e le conversioni.
  • È possibile aggiornare i risultati di alcuni dei campi più popolari.

Campi in Microsoft Word

I campi nei documenti Microsoft Word sono complessi. Esistono oltre 50 tipi di campi (ognuno necessita della propria procedura di calcolo dei risultati), formule ed espressioni, segnalibri e riferimenti, funzioni e vari interruttori. I campi possono anche essere nidificati. Normalmente quando si apre un documento, il risultato del campo (il valore del campo) viene mostrato per tutti i campi del documento. È possibile attivare/disattivare la visualizzazione del risultato del campo o dei codici di campo in Microsoft Word per tutti i campi premendo ALT+F9.

Codice campo Risultato del campo
field-code-result-aspose-words todo:image_alt_text

Inserimento di campi in Microsoft Word

Per inserire un campo in Microsoft Word:

  1. Fare clic sul menu Insert.
  2. Fare clic sul menu a discesa Quick Parts
  3. Selezionare Field
  4. Ti viene presentata una schermata che ti consente di inserire i dettagli del campo. Sul lato sinistro viene fornito un elenco dei possibili campi e sul lato destro c’è una schermata per modificare visivamente le proprietà del campo.
    field-edit-aspose-words
  5. Inoltre è possibile premere il pulsante Field Codes che consente di scrivere direttamente il codice di campo.
    field-properties-aspose-words
  6. Gli interruttori possono essere inseriti anche utilizzando il pulsante Options
    field-options-aspose-words
  7. Utilizzando uno dei due metodi, compilare i campi desiderati con le informazioni appropriate, quindi premere Ok.
  8. Il campo viene inserito nel documento nella posizione corrente del cursore.
    insert-field-aspose-words

Aggiornamento dei campi in Microsoft Word

Per aggiornare un singolo campo in Microsoft Word:

  1. Sposta il cursore nel campo che desideri aggiornare.
  2. Premere F9 per aggiornare il campo.

Per aggiornare tutti i campi in Microsoft Word:

  1. Premere CTRL+A per selezionare tutto il contenuto del documento.
  2. Premere F9 per aggiornare tutti i campi presenti nella selezione.

Passaggio dalla visualizzazione del codice di campo al risultato del campo e viceversa

Per attivare/disattivare i codici di campo di un singolo campo in Microsoft Word:

  1. Spostare il cursore nel campo desiderato.
  2. Premere MAIUSC+F9 per attivare/disattivare il codice di campo solo per questo campo.

Per attivare/disattivare i codici di campo di tutti i campi in Microsoft Word:

  1. Premere ALT+F9

Conversione di campi in testo statico in Microsoft Word

Per convertire un campo dinamico in testo statico in Microsoft Word:

  1. Sposta il cursore nel campo che desideri convertire.
  2. Premere Ctrl+Maiusc+F9 per convertire i campi in testo statico.

Rimozione di un campo in Microsoft Word

Per rimuovere un campo in Microsoft Word:

  1. Seleziona l’intero contenuto che compone il campo. Se vengono visualizzati i codici di campo, è necessario selezionare anche le parentesi graffe di apertura e di chiusura.
  2. Premere Delete per rimuovere l’intero campo.

Campi in Aspose.Words

Quando un documento viene caricato in Aspose.Words, i campi del documento vengono caricati in Aspose.Words Document Object Model come un insieme di componenti separati (nodi). Un singolo campo viene caricato come raccolta di nodi FieldStart, FieldSeparator e FieldEnd insieme al contenuto tra questi nodi. Se un campo non ha un risultato di campo, non ci sarà alcun nodo FieldSeparator. Tutti questi nodi si trovano sempre in linea (come figli di Paragraph o SmartTag.

Il contenuto che costituisce il codice di campo viene archiviato come nodi Run tra FieldStart e FieldSeparator. Il risultato del campo viene archiviato tra i nodi FieldSeparator e FieldEnd e può essere costituito da vari tipi di contenuto. Normalmente il risultato del campo contiene solo testo composto da nodi Run, tuttavia è possibile che il nodo FieldEnd si trovi in un paragrafo completamente diverso, rendendo così il risultato del campo composto anche da nodi a livello di blocco come nodi Table e Paragraph.

In Aspose.Words ciascuno dei nodi FieldXXX deriva da FieldChar. Questa classe fornisce una proprietà per verificare il tipo di campo rappresentato dal nodo specificato tramite la proprietà FieldChar.field_type. Ad esempio FieldType.FIELD_MERGE_FIELD rappresenta un campo di unione nel documento.

Campi supportati durante l’aggiornamento

Il calcolo dei seguenti campi è supportato nella versione attuale di Aspose.Words:

  • = (campo formula)
  • ADDRESSBLOCK
  • AUTHOR
  • COMPARE
  • CREATEDATE
  • DATE
  • DOCPROPERTY
  • DOCVARIABLE
  • GREETINGLINE
  • IF
  • INCLUDETEXT
  • MERGEFIELD
  • MERGEREC
  • MERGESEQ
  • NEXT
  • NEXTIF
  • NUMPAGES
  • PAGE
  • PAGEREF
  • REF
  • SECTION
  • SECTIONPAGES
  • SEQ
  • SET
  • STYLEREF
  • TIME
  • TITLE
  • TOA
  • TOC (inclusi TOT e TOF) -TC

Analisi sofisticata

Aspose.Words segue il modo in cui Microsoft Word elabora i campi e di conseguenza gestisce correttamente:

  • Campi nidificati : IF { =OR({ COMPARE { =2.5 +PRODUCT(3,5 ,8.4) } > 4}, { =2/2 }) } = 1 "Credit not acceptable" "Credit acceptable"
  • L’argomento del campo può essere il risultato di un campo nidificato.
  • I campi possono essere nidificati all’interno di un codice di campo così come nel risultato del campo.
  • Spazi/senza spazi, virgolette/senza virgolette, caratteri di escape nei campi ecc.: MERGEFIELD \f"Text after""Field \n\ame with \" and \\\ and \\\*"\bTextBefor\e
  • Campi che si estendono su più paragrafi.

Campi formula

Aspose.Words fornisce un’implementazione molto seria del motore delle formule e supporta quanto segue:

  • Operatori aritmetici e logici: =(54+4*(6-77)-(5))+(-6-5)/4/5
  • Funzioni: =ABS(-01.4)+2.645/(5.6^3.5)+776457 \\\# "#,##0"
  • Riferimenti ai segnalibri: =IF(C>4, 5,ABS(A)*.76) +3.85
  • Interruttori di formattazione dei numeri: =00000000 \\\# "$#,##0.00;($#,##0.00)"

Sono supportate le seguenti funzioni nelle espressioni: ABS, AND, AVERAGE, COUNT, DEFINED, FALSE, IF, INT, MAX, MIN, MOD, NOT, OR, PRODUCT, ROUND, SIGN, SUM, TRUE.

Campi IF e COMPARE

Solo alcune delle espressioni IF che Aspose.Words può facilmente calcolare dovrebbero darti un’idea di quanto sia potente questa funzionalità:

  • IF 3 > 5.7^4+MAX(4,3) True False
  • IF "abcd" > "abc" True False
  • IF "?ab*" = "1abdsg" True False
  • IF 4 = "2*2" True False
  • COMPARE 3+5/34 < 4.6/3/2

Campi DATE e TIME

Aspose.Words supporta tutte le opzioni di formattazione di data e ora disponibili in Microsoft Word, alcuni esempi sono:

  • DATE @ "d-MMM-yy"
  • DATE @ "d/MM/yyyy h:mm am/pm

Campi Mail Merge

Aspose.Words non impone limiti alla complessità dei campi mail merge nei tuoi documenti e supporta campi formula e IF nidificati e può persino calcolare il nome del campo di unione utilizzando una formula.

Alcuni esempi di campi mail merge supportati da Aspose.Words:

  • Interruttori di campo Mail merge: MERGEFIELD FirstName \\\\\\\\* FirstCap \b "Mr. "
  • Campi di unione nidificati in una formula: IF { MERGEFIELDValue1 } >= {MERGEFIELD Value2 } True False
  • Calcola il nome del campo di unione in fase di esecuzione: MERGEFIELD { IF{MERGEFIELDValue1 } >= {MERGEFIELD Value2 } FirstName"LastName" }
  • Passaggio condizionale al record successivo nell’origine dati: NEXTIF { MERGEFIELDValue1 } <= { =IF(-2.45 >= 6*{MERGEFIELD Value2 }, 2, -.45) }

Interruttori di formato

Un campo in un documento può avere opzioni di formattazione che specificano come deve essere formattato il valore risultante. Aspose.Words supporta le seguenti opzioni di formato:

  • @ - formattazione di data e ora
  • \# - formattazione del numero
  • \\\\* Caps
  • \\\\* PrimoCap
  • \\\\* Inferiore
  • \\\\* Superiore
  • \\\\* CHARFORMAT – formatta il risultato in base al primo carattere del codice di campo.
  • \\\\* MERGEFORMAT – formatta il risultato in base a come è formattato il vecchio risultato.

Date e formattazione dei numeri nei campi

Quando Aspose.Words calcola il risultato di un campo, spesso è necessario analizzare una stringa in un numero o un valore di data e anche formattarla nuovamente in una stringa. Per impostazione predefinita, Aspose.Words utilizza la cultura del thread corrente per eseguire l’analisi e la formattazione durante il calcolo dei valori del campo durante l’aggiornamento del campo e mail merge. Sono inoltre disponibili opzioni sotto forma di classe FieldOptions che consentono un ulteriore controllo su quale cultura viene utilizzata durante l’aggiornamento del campo.

Formattazione utilizzando la cultura del thread corrente

Per controllare la cultura utilizzata durante il calcolo del campo, utilizza semplicemente il metodo locale.setlocale per impostare la cultura di tua scelta prima di richiamare il calcolo del campo. L’esempio seguente mostra come modificare la lingua utilizzata nei campi di formattazione durante l’aggiornamento.

L’utilizzo della lingua corrente per formattare i campi consente a un sistema di controllare in modo semplice e coerente il modo in cui tutti i campi nel documento vengono formattati durante l’aggiornamento dei campi.

Formattazione utilizzando la lingua nel documento

D’altra parte, Microsoft Word formatta ogni singolo campo in base alla lingua del testo trovato nel campo (in particolare, le parti dal codice di campo). A volte durante l’aggiornamento del campo questo potrebbe essere il comportamento desiderato, ad esempio se si hanno documenti globalizzati con contenuti composti da molte lingue diverse e si desidera che ciascun campo rispetti la locale utilizzata dal testo. Aspose.Words supporta anche questa funzionalità.

La classe Document fornisce una proprietà field_options che contiene membri che possono essere utilizzati per controllare il modo in cui i campi vengono aggiornati all’interno del documento. L’esempio seguente mostra come specificare da dove viene scelta la lingua utilizzata per la formattazione della data durante l’aggiornamento del campo e mail merge.

Trovare il codice di campo e il risultato del campo

Un campo inserito utilizzando DocumentBuilder.insert_field restituisce un oggetto Field. Questa è una classe di facciata che fornisce metodi utili per trovare rapidamente tali proprietà di un campo. Nota se stai cercando solo i nomi dei campi di unione nel documento, puoi invece utilizzare il metodo integrato MailMerge.get_field_names. L’esempio seguente mostra come ottenere i nomi di tutti i campi di unione in un documento.

Come rinominare i campi unione

L’esempio seguente mostra come rinominare i campi di unione in un documento di Word.