Condividi tramite


Procedura: Modificare valori letterali XML (Visual Basic)

Visual Basic offre modi pratici per modificare i valori letterali XML. È possibile aggiungere o eliminare elementi e attributi ed è anche possibile sostituire un elemento esistente con un nuovo elemento XML. In questo argomento vengono forniti diversi esempi di come modificare un valore letterale XML esistente.

Per modificare il valore di un letterale XML

  1. Per modificare il valore di un valore letterale XML, ottenere un riferimento al valore letterale XML e impostare la Value proprietà sul valore desiderato.

    Nell'esempio di codice seguente viene aggiornato il valore di tutti gli <elementi Price> in un documento XML.

    For Each book In From element In catalog.<Catalog>.<Book>
      book.<Price>.Value = (book.<Price>.Value * 1.05).ToString("#.00")
    Next
    

    Di seguito viene illustrato il codice XML di origine di esempio e il codice XML modificato da questo esempio di codice.

    XML di origine:

    <?xml version="1.0"?>
    <Catalog>
      <Book id="bk101">
        <Author>Garghentini, Davide</Author>
        <Title>XML Developer's Guide</Title>
        <Price>44.95</Price>
      </Book>
      <Book id="bk331">
        <Author>Spencer, Phil</Author>
        <Title>Developing Applications with Visual Basic .NET</Title>
        <Price>45.95</Price>
      </Book>
    </Catalog>
    

    XML modificato:

    <?xml version="1.0"?>
    <Catalog>
      <Book id="bk101">
        <Author>Garghentini, Davide</Author>
        <Title>XML Developer's Guide</Title>
        <Price>47.20</Price>
      </Book>
      <Book id="bk331">
        <Author>Spencer, Phil</Author>
        <Title>Developing Applications with Visual Basic .NET</Title>
        <Price>48.25</Price>
      </Book>
    </Catalog>
    

    Annotazioni

    La Value proprietà fa riferimento al primo elemento XML di una raccolta. Se in una raccolta sono presenti più elementi con lo stesso nome, l'impostazione della Value proprietà influisce solo sul primo elemento dell'insieme.

Per aggiungere un attributo a un valore letterale XML

  1. Per aggiungere un attributo a un valore letterale XML, ottenere innanzitutto un riferimento al valore letterale XML. È quindi possibile aggiungere un attributo aggiungendo una nuova proprietà dell'asse degli attributi XML. Anche possibile aggiungere un oggetto XAttribute al valore letterale XML usando il metodo Add. L'esempio seguente mostra entrambe le opzioni.

    Dim newAttribute = "editorEmail"
    Dim editorID = "someone@example.com"
    For Each book In From element In catalog.<Catalog>.<Book>
      ' Add an attribute by using an XML attribute axis property.
      book.@genre = "Computer"
    
      ' Add an attribute to the Attributes collection.
      book.Add(New XAttribute(newAttribute, editorID))
    Next
    

    Di seguito viene illustrato il codice XML di origine di esempio e il codice XML modificato da questo esempio di codice.

    XML di origine:

    <?xml version="1.0"?>
    <Catalog>
      <Book id="bk101" >
        <Author>Garghentini, Davide</Author>
        <Title>XML Developer's Guide</Title>
        <Price>44.95</Price>
      </Book>
      <Book id="bk331">
        <Author>Spencer, Phil</Author>
        <Title>Developing Applications with Visual Basic .NET</Title>
        <Price>45.95</Price>
      </Book>
    </Catalog>
    

    XML modificato:

    <?xml version="1.0"?>
    <Catalog>
      <Book id="bk101" genre="Computer" editorEmail="someone@example.com">
        <Author>Garghentini, Davide</Author>
        <Title>XML Developer's Guide</Title>
        <Price>44.95</Price>
      </Book>
      <Book id="bk331" genre="Computer" editorEmail="someone@example.com">
        <Author>Spencer, Phil</Author>
        <Title>Developing Applications with Visual Basic .NET</Title>
        <Price>45.95</Price>
      </Book>
    </Catalog>
    

    Per altre informazioni sulle proprietà dell'asse degli attributi XML, vedere Proprietà dell'asse degli attributi XML.

Per aggiungere un elemento a un valore letterale XML

  1. Per aggiungere un elemento a un valore letterale XML, ottenere innanzitutto un riferimento al valore letterale XML. È quindi possibile aggiungere un nuovo XElement oggetto come ultimo sottoelemento dell'elemento usando il Add metodo . È possibile aggiungere un nuovo XElement oggetto come primo sottoelemento usando il AddFirst metodo .

    Per aggiungere un nuovo elemento in una posizione specifica rispetto ad altri sottoelementi, ottenere prima un riferimento a un sottoelemento adiacente. È quindi possibile aggiungere il nuovo XElement oggetto prima dell'elemento secondario adiacente usando il AddBeforeSelf metodo . È anche possibile aggiungere il nuovo XElement oggetto dopo l'elemento secondario adiacente usando il AddAfterSelf metodo .

    Nell'esempio seguente vengono illustrati esempi di ognuna di queste tecniche.

    Dim vbBook = From book In catalog.<Catalog>.<Book> 
                 Where book.<Title>.Value = 
                   "Developing Applications with Visual Basic .NET"
    
    vbBook(0).AddFirst(<Publisher>Microsoft Press</Publisher>)
    
    vbBook(0).Add(<PublishDate>2005-2-14</PublishDate>)
    
    vbBook(0).AddAfterSelf(<Book id="bk999"></Book>)
    
    vbBook(0).AddBeforeSelf(<Book id="bk000"></Book>)
    

    Di seguito viene illustrato il codice XML di origine di esempio e il codice XML modificato da questo esempio di codice.

    XML di origine:

    <?xml version="1.0"?>
    <Catalog>
      <Book id="bk101" >
        <Author>Garghentini, Davide</Author>
        <Title>XML Developer's Guide</Title>
        <Price>44.95</Price>
      </Book>
      <Book id="bk331">
        <Author>Spencer, Phil</Author>
        <Title>Developing Applications with Visual Basic .NET</Title>
        <Price>45.95</Price>
      </Book>
    </Catalog>
    

    XML modificato:

    <?xml version="1.0"?>
    <Catalog>
      <Book id="bk101" >
        <Author>Garghentini, Davide</Author>
        <Title>XML Developer's Guide</Title>
        <Price>44.95</Price>
      </Book>
      <Book id="bk000"></Book>
      <Book id="bk331">
        <Publisher>Microsoft Press</Publisher>
        <Author>Spencer, Phil</Author>
        <Title>Developing Applications with Visual Basic .NET</Title>
        <Price>45.95</Price>
        <PublishDate>2005-2-14</PublishDate>
      </Book>
      <Book id="bk999"></Book>
    </Catalog>
    

Per rimuovere un elemento o un attributo da un letterale XML

  1. Per rimuovere un elemento o un attributo da un valore letterale XML, ottenere un riferimento all'elemento o all'attributo e chiamare il metodo Remove, come illustrato nell'esempio seguente.

    For Each book In From element In catalog.<Catalog>.<Book>
      book.Attributes("genre").Remove()
    Next
    
    For Each book In From element In catalog.<Catalog>.<Book> 
                     Where element.@id = "bk999"
      book.Remove()
    Next
    

    Di seguito viene illustrato il codice XML di origine di esempio e il codice XML modificato da questo esempio di codice.

    XML di origine:

    <?xml version="1.0"?>
    <Catalog>
      <Book id="bk101" genre="Computer" editorEmail="someone@example.com">
        <Author>Garghentini, Davide</Author>
        <Title>XML Developer's Guide</Title>
        <Price>44.95</Price>
      </Book>
      <Book id="bk000"></Book>
      <Book id="bk331" genre="Computer" editorEmail="someone@example.com">
        <Author>Spencer, Phil</Author>
        <Title>Developing Applications with Visual Basic .NET</Title>
        <Price>45.95</Price>
      </Book>
      <Book id="bk999"></Book>
    </Catalog>
    

    XML modificato:

    <?xml version="1.0"?>
    <Catalog>
      <Book id="bk101" editorEmail="someone@example.com">
        <Author>Garghentini, Davide</Author>
        <Title>XML Developer's Guide</Title>
        <Price>44.95</Price>
      </Book>
      <Book id="bk000"></Book>
      <Book id="bk331" editorEmail="someone@example.com">
        <Author>Spencer, Phil</Author>
        <Title>Developing Applications with Visual Basic .NET</Title>
        <Price>45.95</Price>
      </Book></Catalog>
    

    Per rimuovere tutti gli elementi o attributi da un valore letterale XML, si ottiene un riferimento al valore letterale XML e si chiama il metodo RemoveAll.

Per modificare un valore letterale XML

  1. Per modificare il nome di un elemento XML, ottenere innanzitutto un riferimento all'elemento . È quindi possibile creare un nuovo XElement oggetto con un nuovo nome e passare il nuovo XElement oggetto al ReplaceWith metodo dell'oggetto esistente XElement .

    Se l'elemento che si sostituisce dispone di sottoelementi che devono essere mantenuti, impostare il valore del nuovo XElement oggetto sulla Nodes proprietà dell'elemento esistente. Verrà impostato il valore del nuovo elemento sul codice XML interno dell'elemento esistente. In caso contrario, è possibile impostare il valore del nuovo elemento sulla Value proprietà dell'elemento esistente.

    Nell'esempio di codice seguente vengono sostituiti tutti gli <elementi Description> con un <elemento Abstract> . Il contenuto dell'elemento <Description> è preservato nel nuovo <Abstract> utilizzando la proprietà Nodes dell'oggetto <Description>XElement.

    For Each desc In From element In catalog.<Catalog>.<Book>.<Description>
      ' Replace and preserve inner XML.
      desc.ReplaceWith(<Abstract><%= desc.Nodes %></Abstract>)
    Next
    
    For Each price In From element In catalog.<Catalog>.<Book>.<Price>
      ' Replace with text value.
      price.ReplaceWith(<MSRP><%= price.Value %></MSRP>)
    Next
    

    Di seguito viene illustrato il codice XML di origine di esempio e il codice XML modificato da questo esempio di codice.

    XML di origine:

    <?xml version="1.0"?>
    <Catalog>
      <Book id="bk101">
        <Author>Garghentini, Davide</Author>
        <Title>XML Developer's Guide</Title>
        <Price>44.95</Price>
        <Description>
          An in-depth look at creating applications
          with <technology>XML</technology>. For
          <audience>beginners</audience> or
          <audience>advanced</audience> developers.
        </Description>
      </Book>
      <Book id="bk331">
        <Author>Spencer, Phil</Author>
        <Title>Developing Applications with Visual Basic .NET</Title>
        <Price>45.95</Price>
        <Description>
          Get the expert insights, practical code samples, and best
          practices you need to advance your expertise with
          <technology>Visual Basic .NET</technology>.
          Learn how to create faster, more reliable applications
          based on professional, pragmatic guidance by today's top
          <audience>developers</audience>.
        </Description>
      </Book>
    </Catalog>
    

    XML modificato:

    <?xml version="1.0"?>
    <Catalog>
      <Book id="bk101">
        <Author>Garghentini, Davide</Author>
        <Title>XML Developer's Guide</Title>
        <MSRP>44.95</MSRP>    <Abstract>
          An in-depth look at creating applications
          with <technology>XML</technology>. For
          <audience>beginners</audience> or
          <audience>advanced</audience> developers.
        </Abstract>
      </Book>
      <Book id="bk331">
        <Author>Spencer, Phil</Author>
        <Title>Developing Applications with Visual Basic .NET</Title>
        <MSRP>45.95</MSRP>    <Abstract>
          Get the expert insights, practical code samples, and best
          practices you need to advance your expertise with
          <technology>Visual Basic .NET</technology>.
          Learn how to create faster, more reliable applications
          based on professional, pragmatic guidance by today's top
          <audience>developers</audience>.
        </Abstract>
      </Book>
    </Catalog>
    

Vedere anche