golang动态解析xml

package main

import (
	"encoding/xml"
	"fmt"
	"mahonia"
	"os"
	"strconv"
	"text/template"
)

type Attribute struct {
	Name  string
	Value string
}

type Token struct {
	Name       string
	Attributes []Attribute
	Tokens     []Token
}

type Result struct {
	Root Token
}

var result = Result{}

func main() {

	if !parse("config.xml") {
		return
	}

	if !output("code_h.tpl", "code.h") {
		return
	}

	if !output("code_cpp.tpl", "code.cpp") {
		return
	}

	fmt.Println("OK")
}

func parse_token(decoder *xml.Decoder, tt xml.Token, mytoken *Token) {

	token := tt.(xml.StartElement)
	name := token.Name.Local
	mytoken.Name = name

	for _, attr := range token.Attr {
		attrName := attr.Name.Local
		attrValue := attr.Value

		attr := Attribute{Name: attrName, Value: attrValue}

		mytoken.Attributes = append(mytoken.Attributes, attr)
	}

	var t xml.Token
	var err error

	for t, err = decoder.Token(); err == nil; t, err = decoder.Token() {

		switch t.(type) {
		// 处理元素开始(标签)
		case xml.StartElement:

			mytoken.Tokens = append(mytoken.Tokens, Token{})

			parse_token(decoder, t, &mytoken.Tokens[len(mytoken.Tokens)-1])

			// 处理元素结束(标签)
		case xml.EndElement:
			return
		case xml.CharData:
		default:
			return
		}
	}
}

func parse(filename string) bool {
	file, err := os.Open(filename)
	if err != nil {
		fmt.Println(err)
		return false
	}

	var t xml.Token

	decoder := xml.NewDecoder(file)
	t, decerr := decoder.Token()
	if decerr != nil {
		fmt.Println(decerr)
		return false
	}
	parse_token(decoder, t, &result.Root)
	fmt.Println("result", result.Root)
	return true
}

func genlist(n string) []string {
	num, _ := strconv.Atoi(n)
	ret := make([]string, num)
	for i := 0; i < num; i++ {
		ret[i] = strconv.Itoa(i)
	}
	return ret
}

func iconv(str string) string {
	enc := mahonia.NewEncoder("gb2312")
	return enc.ConvertString(str)
}

func output(src string, des string) bool {

	file, err := os.Create(des)
	if err != nil {
		fmt.Println(err)
		return false
	}

	t := template.New("text")
	if err != nil {
		fmt.Println(err)
		return false
	}

	t = t.Funcs(template.FuncMap{"genlist": genlist, "iconv": iconv})

	srcfile, err := os.Open(src)
	if err != nil {
		fmt.Println(err)
		return false
	}

	var buffer [1024 * 1024]byte
	n, rerr := srcfile.Read(buffer[0:])
	if rerr != nil {
		fmt.Println(rerr)
		return false
	}

	t, err = t.Parse(string(buffer[0:n]))
	if err != nil {
		fmt.Println(err)
		return false
	}

	err = t.Execute(file, result.Root)
	if err != nil {
		fmt.Println(err)
		return false
	}

	return true
}

可以使用 Go 标准库中的 `encoding/xml` 和 `html/template` 包来实现将 XML 转换为 HTML 的功能。 首先,你需要定义一个结构体来存放 XML 数据,例如: ```go type Person struct { XMLName xml.Name `xml:"person"` Name string `xml:"name"` Age int `xml:"age"` } ``` 这个结构体对应一个 XML 格式的数据: ```xml <person> <name>John</name> <age>30</age> </person> ``` 接下来,你可以使用 `encoding/xml` 包中的 `Unmarshal` 函数将 XML 数据解析为结构体: ```go data := []byte(` <person> <name>John</name> <age>30</age> </person> `) var person Person err := xml.Unmarshal(data, &person) if err != nil { panic(err) } ``` 此时,`person` 变量就包含了 XML 数据的内容。 最后,你可以使用 `html/template` 包中的模板引擎来生成 HTML 代码: ```go templateStr := ` <html> <head> <title>{{.Name}}'s page</title> </head> <body> <h1>{{.Name}}</h1> <p>Age: {{.Age}}</p> </body> </html> ` t, err := template.New("webpage").Parse(templateStr) if err != nil { panic(err) } var buf bytes.Buffer err = t.Execute(&buf, person) if err != nil { panic(err) } htmlCode := buf.String() fmt.Println(htmlCode) ``` 在这个例子中,我们使用了一个简单的模板,将 XML 数据转换为 HTML 页面。`{{.Name}}` 和 `{{.Age}}` 是模板中的占位符,它们会被实际的数据替换掉。 完整的示例代码如下: ```go package main import ( "bytes" "encoding/xml" "fmt" "html/template" ) type Person struct { XMLName xml.Name `xml:"person"` Name string `xml:"name"` Age int `xml:"age"` } func main() { data := []byte(` <person> <name>John</name> <age>30</age> </person> `) var person Person err := xml.Unmarshal(data, &person) if err != nil { panic(err) } templateStr := ` <html> <head> <title>{{.Name}}'s page</title> </head> <body> <h1>{{.Name}}</h1> <p>Age: {{.Age}}</p> </body> </html> ` t, err := template.New("webpage").Parse(templateStr) if err != nil { panic(err) } var buf bytes.Buffer err = t.Execute(&buf, person) if err != nil { panic(err) } htmlCode := buf.String() fmt.Println(htmlCode) } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值