Как записать вывод шаблона в файл на Голанге? - PullRequest
0 голосов
/ 24 ноября 2018

Я использую следующий код, который работает нормально, но теперь я хочу напечатать шаблон в файл и попробовал следующее, но получил ошибку

package main

import (
    "html/template"
    "log"
    "os"
)

func main() {
    t := template.Must(template.New("").Parse(`{{- range .}}{{.}}:
    echo "from {{.}}"
{{end}}
`))
    t.Execute(os.Stdout, []string{"app1", "app2", "app3"})

    f, err := os.Create("./myfile")
    if err != nil {
        log.Println("create file: ", err)
        return
    }
    err = t.Execute(f, t)
    if err != nil {
        log.Print("execute: ", err)
        return
    }
    f.Close()
}

Ошибка:

execute: template: :1:10: executing "" at <.>: range can't iterate over {0xc00000e520 0xc00001e400 0xc0000b3000 0xc00009e0a2}

Ответы [ 3 ]

0 голосов
/ 24 ноября 2018

Параметр, который вы передаете во исполнение шаблона во второй раз, должен совпадать с тем, который вы передаете в первый раз.

Первое, что вы делаете:

t.Execute(os.Stdout, []string{"app1", "app2", "app3"})

Второе, что вы делаете:

err = t.Execute(f, t)

Вы передали сам шаблон (t).Измените его на:

err = t.Execute(f, []string{"app1", "app2", "app3"})

Ваш шаблон выполняет итерацию по переданному параметру (с действием {{range}}), который работает при передаче фрагмента, и не работает при передаче шаблона, это указательдля структуры, это не то, что механизм шаблонов может перебирать.

0 голосов
/ 24 ноября 2018

Используйте массив в качестве второго аргумента, а не сам шаблон.

package main

import (
        "html/template"
        "log"
        "os"
)

func main() {
        t := template.Must(template.New("").Parse(`{{- range .}}{{.}}:
        echo "from {{.}}"
{{end}}
`))
        t.Execute(os.Stdout, []string{"app1", "app2", "app3"})

        f, err := os.Create("./myfile")
        if err != nil {
                log.Println("create file: ", err)
                return
        }
        err = t.Execute(f, []string{"app1", "app2", "app3"})
        if err != nil {
                log.Print("execute: ", err)
                return
        }
        f.Close()
}

Вывод:

app1:
    echo "from app1"
app2:
    echo "from app2"
app3:
    echo "from app3"

И содержимое myfile равно

app1:
    echo "from app1"
app2:
    echo "from app2"
app3:
    echo "from app3"
0 голосов
/ 24 ноября 2018

Вы указали неверный параметр:

err = t.Execute(f, t)

Это должно быть

err = t.Execute(f,[]string{"app1", "app2", "app3"})
...