Rumah >pembangunan bahagian belakang >Golang >tatasusunan golang ke xml

tatasusunan golang ke xml

PHPz
PHPzasal
2023-05-10 09:48:37715semak imbas

Apabila golang menjadi semakin popular dalam bidang pembangunan web dan pengkomputeran awan, pemprosesan xml golang telah beransur-ansur mendapat perhatian. Dalam projek sebenar, kami selalunya perlu menghantar dan menyimpan data dalam format xml, dan kami juga perlu menghuraikan data daripada xml dan menukarnya menjadi tatasusunan pergi. Oleh itu, artikel ini akan memperkenalkan cara menukar tatasusunan go ke dalam format xml dan menggunakannya dalam pembangunan sebenar.

1. Pakej xml golang

pakej xml golang ialah pakej teras untuk memproses xml. Pakej xml Golang menyokong pengekodan dan penyahkodan pelbagai jenis seperti struktur, nombor dan rentetan. Antara fungsi yang disediakan oleh pakej ini, fungsi Marshal dan Unmarshal ialah dua fungsi yang paling biasa digunakan, yang digunakan untuk mensiri dan menghuraikan data xml masing-masing.

2. Tukar tatasusunan kepada xml

Walaupun pakej xml golang menyokong pengekodan dan penyahkodan pelbagai jenis, ia tidak menyediakan antara muka yang sepadan untuk bersiri dan penyahserilan tatasusunan. Oleh itu, apabila pengekodan dan penyahkodan tatasusunan xml, kita perlu menentukan sendiri kaedah penukaran.

  1. Array kepada xml

Idea kami untuk menukar tatasusunan kepada format xml ialah: mula-mula menukar tatasusunan kepada struktur, dan kemudian menukar struktur kepada xml. Seterusnya, kami mula-mula mentakrifkan Pengguna jenis tersuai, yang mempunyai tiga medan: id, nama dan umur.

type User struct {
    Id   string `xml:"id"`
    Name string `xml:"name"`
    Age  int    `xml:"age"`
}

Kemudian tentukan jenis data Pengguna, yang juga mempunyai 3 medan, iaitu XMLName, Versi dan Item tatasusunan pengguna.

type Users struct {
    XMLName xml.Name `xml:"users"`
    Version string   `xml:"version,attr"`
    Items   []User   `xml:"user"`
}

Seterusnya, kami mentakrifkan fungsi untuk menukar tatasusunan kepada format xml. Idea asas fungsi ini adalah untuk mencipta contoh jenis Pengguna, menukar setiap elemen dalam tatasusunan kepada jenis Pengguna, dan menambahnya pada tatasusunan Item Pengguna Akhir sekali, gunakan fungsi xml.Marshal untuk menukar Contoh pengguna ke dalam bait dalam format xml.

func ArrayToXml(arr []interface{}) ([]byte, error) {
    var users Users
    users.Version = "1.0"
    for i := 0; i < len(arr); i++ {
        var user User
        if v, ok := arr[i].(map[string]interface{}); ok {
            user.Id = v["id"].(string)
            user.Name = v["name"].(string)
            user.Age = v["age"].(int)
            users.Items = append(users.Items, user)
        }
    }
    return xml.Marshal(users)
}

Dalam kod di atas, pembolehubah arr merujuk kepada tatasusunan apa-apa jenis dan setiap elemen daripadanya adalah daripada jenis peta[rentetan]antara muka{}. Penegasan jenis digunakan di sini untuk memaksa pembolehubah jenis peta[rentetan]antara muka{} ke dalam jenis yang sepadan untuk mencapai penghuraian elemen dalam tatasusunan.

  1. Xml kepada tatasusunan

Sama seperti menukar tatasusunan kepada xml, idea untuk menukar xml kepada tatasusunan ialah: mula-mula menukar xml kepada struktur, dan kemudian tukar struktur Tukar kepada tatasusunan jenis yang sepadan.

Fungsi Unmarshal disediakan dalam pakej xml golang, yang boleh menukar tatasusunan bait dalam format xml kepada struktur. Kod berikut menunjukkan cara menukar tatasusunan bait dalam format xml kepada contoh Pengguna:

func XmlToArray(data []byte) ([]interface{}, error) {
    var users Users
    var arr []interface{}
    err := xml.Unmarshal(data, &users)
    if err != nil {
        return nil, err
    }
    for _, item := range users.Items {
        m := make(map[string]interface{})
        m["id"] = item.Id
        m["name"] = item.Name
        m["age"] = item.Age
        arr = append(arr, m)
    }
    return arr, nil
}

Dalam kod di atas, kami menukar contoh jenis Pengguna yang dihuraikan daripada xml kepada jenis tatasusunan. Gelung for digunakan di sini untuk menukar setiap tika jenis Pengguna dalam tika Pengguna kepada jenis peta[rentetan]antara muka{} dan menambahkannya pada tatasusunan.

3. Ujian

Kami telah berjaya melaksanakan operasi asas menukar tatasusunan ke dalam format xml dan menukar format xml kepada tatasusunan Mari lakukan ujian:

func main() {
    arr := make([]interface{}, 0)
    m1 := map[string]interface{}{
        "id":   "1",
        "name": "Tom",
        "age":  20,
    }
    m2 := map[string]interface{}{
        "id":   "2",
        "name": "Jerry",
        "age":  22,
    }
    arr = append(arr, m1)
    arr = append(arr, m2)

    data, err1 := ArrayToXml(arr)
    if err1 != nil {
        fmt.Println("error:", err1)
        return
    }
    fmt.Println("array to xml:", string(data))

    arr2, err2 := XmlToArray(data)
    if err2 != nil {
        fmt.Println("error:", err2)
        return
    }
    fmt.Println("xml to array:", arr2)
}

Menjalankan perkara di atas kod, kita boleh melihat hasil berikut:

array to xml: <?xml version="1.0" encoding="UTF-8"?>
<users version="1.0">
    <user>
        <id>1</id><name>Tom</name><age>20</age>
    </user>
    <user>
        <id>2</id><name>Jerry</name><age>22</age>
    </user>
</users>

xml to array: [map[id:1 name:Tom age:20] map[id:2 name:Jerry age:22]] 

Ini bermakna kami berjaya menukar tatasusunan ke dalam format xml dan boleh menghuraikan data format xml dengan betul ke dalam tatasusunan jenis yang sepadan.

4. Ringkasan

Artikel ini terutamanya memperkenalkan cara menggunakan pakej xml golang untuk menukar tatasusunan kepada format xml dan menukar format xml kepada tatasusunan. Walaupun pakej xml golang sendiri tidak menyediakan sokongan yang sepadan untuk tatasusunan, kami boleh mensiri dan menyahsiri tatasusunan dengan menukar tatasusunan kepada struktur dan menukar struktur kepada xml. Dalam projek sebenar, kami perlu melaksanakan pembangunan tersuai mengikut keperluan khusus dan terus menambah baik serta mengoptimumkan antara muka untuk mencapai hasil penggunaan yang lebih baik.

Atas ialah kandungan terperinci tatasusunan golang ke xml. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn