Go by Example: XML

Go ofrece soporte integrado para XML y formatos similares a XML con el paquete encoding.xml.

package main
import (
    "encoding/xml"
    "fmt"
)

Plant será mapeado a XML. De manera similar a los ejemplos de JSON, las etiquetas de campo contienen directivas para el codificador y decodificador. Aquí usamos algunas características especiales del paquete XML: el nombre de campo XMLName dicta el nombre del elemento XML que representa esta estructura; id,attr significa que el campo Id es un atributo XML en lugar de un elemento anidado.

type Plant struct {
    XMLName xml.Name `xml:"plant"`
    Id      int      `xml:"id,attr"`
    Name    string   `xml:"name"`
    Origin  []string `xml:"origin"`
}
func (p Plant) String() string {
    return fmt.Sprintf("Plant id=%v, name=%v, origin=%v",
        p.Id, p.Name, p.Origin)
}
func main() {
    coffee := &Plant{Id: 27, Name: "Coffee"}
    coffee.Origin = []string{"Ethiopia", "Brazil"}

Emitir XML representando nuestra planta; utilizando MarshalIndent para producir una salida más legible para el ser humano.

    out, _ := xml.MarshalIndent(coffee, " ", "  ")
    fmt.Println(string(out))

Para agregar un encabezado XML genérico a la salida, añádalo explícitamente.

    fmt.Println(xml.Header + string(out))

Utilice Unmarshal para analizar un flujo de bytes con XML en una estructura de datos. Si el XML está mal formado o no se puede mapear a Plant, se devolverá un error descriptivo.

    var p Plant
    if err := xml.Unmarshal(out, &p); err != nil {
        panic(err)
    }
    fmt.Println(p)
    tomato := &Plant{Id: 81, Name: "Tomato"}
    tomato.Origin = []string{"Mexico", "California"}

La etiqueta de campo parent>child>plant indica al codificador que anide todos los plants bajo <parent><child>...

    type Nesting struct {
        XMLName xml.Name `xml:"nesting"`
        Plants  []*Plant `xml:"parent>child>plant"`
    }
    nesting := &Nesting{}
    nesting.Plants = []*Plant{coffee, tomato}
    out, _ = xml.MarshalIndent(nesting, " ", "  ")
    fmt.Println(string(out))
}
$ go run xml.go
 <plant id="27">
   <name>Coffee</name>
   <origin>Ethiopia</origin>
   <origin>Brazil</origin>
 </plant>
<?xml version="1.0" encoding="UTF-8"?>
 <plant id="27">
   <name>Coffee</name>
   <origin>Ethiopia</origin>
   <origin>Brazil</origin>
 </plant>
Plant id=27, name=Coffee, origin=[Ethiopia Brazil]
 <nesting>
   <parent>
     <child>
       <plant id="27">
         <name>Coffee</name>
         <origin>Ethiopia</origin>
         <origin>Brazil</origin>
       </plant>
       <plant id="81">
         <name>Tomato</name>
         <origin>Mexico</origin>
         <origin>California</origin>
       </plant>
     </child>
   </parent>
 </nesting>

Siguiente ejemplo: Time.