CustomXmlPart
Contenuti
[
Nascondere
]CustomXmlPart class
Rappresenta una parte di archiviazione dati XML personalizzata (dati XML personalizzati all’interno di un pacchetto).
Per saperne di più, visita ilTag di documenti strutturati o controllo del contenuto articolo di documentazione.
public class CustomXmlPart
Costruttori
Nome | Descrizione |
---|---|
CustomXmlPart() | Default_Costruttore |
Proprietà
Nome | Descrizione |
---|---|
Data { get; set; } | Ottiene o imposta il contenuto XML di questa parte di archiviazione dati XML personalizzata. |
DataChecksum { get; } | Specifica un checksum del controllo di ridondanza ciclico (CRC) diData contenuto. |
Id { get; set; } | Ottiene o imposta la stringa che identifica questa parte XML personalizzata all’interno di un documento OOXML. |
Schemas { get; } | Specifica l’insieme di schemi XML associati a questa parte XML personalizzata. |
Metodi
Nome | Descrizione |
---|---|
Clone() | Crea una copia “abbastanza profonda” dell’oggetto. Non duplica i byte del fileData valore. |
Osservazioni
Un documento DOCX o DOC può contenere una o più parti di archiviazione dati XML personalizzate. Aspose.Words preserva e consente di creare ed estrarre dati XML personalizzati tramite il fileCustomXmlParts
collezione.
Esempi
Mostra come creare un tag di documento strutturato con dati XML personalizzati.
Document doc = new Document();
// Costruisce una parte XML che contiene dati e la aggiunge alla raccolta del documento.
// Se abilitiamo la scheda "Sviluppatore" in Microsoft Word,
// possiamo trovare gli elementi di questa raccolta nel "riquadro di mappatura XML", insieme ad alcuni elementi predefiniti.
string xmlPartId = Guid.NewGuid().ToString("B");
string xmlPartContent = "<root><text>Hello world!</text></root>";
CustomXmlPart xmlPart = doc.CustomXmlParts.Add(xmlPartId, xmlPartContent);
Assert.AreEqual(Encoding.ASCII.GetBytes(xmlPartContent), xmlPart.Data);
Assert.AreEqual(xmlPartId, xmlPart.Id);
// Di seguito sono riportati due modi per fare riferimento alle parti XML.
// 1 - Tramite un indice nella raccolta di parti XML personalizzate:
Assert.AreEqual(xmlPart, doc.CustomXmlParts[0]);
// 2 - Per GUID:
Assert.AreEqual(xmlPart, doc.CustomXmlParts.GetById(xmlPartId));
// Aggiunge un'associazione allo schema XML.
xmlPart.Schemas.Add("http://www.w3.org/2001/XMLSchema");
// Clona una parte, quindi inseriscila nella raccolta.
CustomXmlPart xmlPartClone = xmlPart.Clone();
xmlPartClone.Id = Guid.NewGuid().ToString("B");
doc.CustomXmlParts.Add(xmlPartClone);
Assert.AreEqual(2, doc.CustomXmlParts.Count);
// Scorrere la raccolta e stampare il contenuto di ciascuna parte.
using (IEnumerator<CustomXmlPart> enumerator = doc.CustomXmlParts.GetEnumerator())
{
int index = 0;
while (enumerator.MoveNext())
{
Console.WriteLine($"XML part index {index}, ID: {enumerator.Current.Id}");
Console.WriteLine($"\tContent: {Encoding.UTF8.GetString(enumerator.Current.Data)}");
index++;
}
}
// Utilizza il metodo "RemoveAt" per rimuovere la parte clonata per indice.
doc.CustomXmlParts.RemoveAt(1);
Assert.AreEqual(1, doc.CustomXmlParts.Count);
// Clona la raccolta di parti XML, quindi utilizza il metodo "Clear" per rimuovere tutti i suoi elementi contemporaneamente.
CustomXmlPartCollection customXmlParts = doc.CustomXmlParts.Clone();
customXmlParts.Clear();
// Crea un tag di documento strutturato che visualizzerà il contenuto della nostra parte e lo inserirà nel corpo del documento.
StructuredDocumentTag tag = new StructuredDocumentTag(doc, SdtType.PlainText, MarkupLevel.Block);
tag.XmlMapping.SetMapping(xmlPart, "/root[1]/text[1]", string.Empty);
doc.FirstSection.Body.AppendChild(tag);
doc.Save(ArtifactsDir + "StructuredDocumentTag.CustomXml.docx");
Guarda anche
- spazio dei nomi Aspose.Words.Markup
- assemblea Aspose.Words