• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            Fork me on GitHub
            隨筆 - 215  文章 - 13  trackbacks - 0
            <2017年5月>
            30123456
            78910111213
            14151617181920
            21222324252627
            28293031123
            45678910


            專注即時通訊及網游服務端編程
            ------------------------------------
            Openresty 官方模塊
            Openresty 標準模塊(Opm)
            Openresty 三方模塊
            ------------------------------------
            本博收藏大部分文章為轉載,并在文章開頭給出了原文出處,如有再轉,敬請保留相關信息,這是大家對原創作者勞動成果的自覺尊重!!如為您帶來不便,請于本博下留言,謝謝配合。

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            相冊

            Awesome

            Blog

            Book

            GitHub

            Link

            搜索

            •  

            積分與排名

            • 積分 - 217538
            • 排名 - 118

            最新評論

            閱讀排行榜

            http://stackoverflow.com/questions/11123865/golang-format-a-string-without-printing

            1. Simple strings

            For "simple" strings (typically what fits into a line) the simplest solution is using fmt.Sprintf() and friends (fmt.Sprint(), fmt.Sprintln()). These are analog to the functions without the starter Sletter, but these Sxxx() variants return the result as a string instead of printing them to the standard output.

            For example:

            s := fmt.Sprintf("Hi, my name is %s and I'm %d years old.", "Bob", 23)
            

            The variable s will be initialized with the value:

            Hi, my name is Bob and I'm 23 years old.
            

            Tip: If you just want to concatenate values of different types, you may not automatically need to use Sprintf() (which requires a format string) as Sprint() does exactly this. See this example:

            i := 23
            s := fmt.Sprint("[age:", i, "]") // s will be "[age:23]"
            

            For concatenating only strings, you may also use strings.Join() where you can specify a custom separator string (to be placed between the strings to join).

            Try these on the Go Playground.

            2. Complex strings (documents)

            If the string you're trying to create is more complex (e.g. a multi-line email message), fmt.Sprintf()becomes less readable and less efficient (especially if you have to do this many times).

            For this the standard library provides the packages text/template and html/template. These packages implement data-driven templates for generating textual output. html/template is for generating HTML output safe against code injection. It provides the same interface as package text/template and should be used instead of text/template whenever the output is HTML.

            Using the template packages basically requires you to provide a static template in the form of a string value (which may be originating from a file in which case you only provide the file name) which may contain static text, and actions which are processed and executed when the engine processes the template and generates the output.

            You may provide parameters which are included/substituted in the static template and which may control the output generation process. Typical form of such parameters are structs and map values which may be nested.

            Example:

            For example let's say you want to generate email messages that look like this:

            Hi [name]!
            
            Your account is ready, your user name is: [user-name]
            
            You have the following roles assigned:
            [role#1], [role#2], ... [role#n]
            

            To generate email message bodies like this, you could use the following static template:

            const emailTmpl = `Hi {{.Name}}!
            
            Your account is ready, your user name is: {{.UserName}}
            
            You have the following roles assigned:
            {{range $i, $r := .Roles}}{{if ne $i 0}}, {{end}}{{.}}{{end}}
            `
            

            And provide data like this for executing it:

            data := map[string]interface{}{
                "Name":     "Bob",
                "UserName": "bob92",
                "Roles":    []string{"dbteam", "uiteam", "tester"},
            }
            

            Normally output of templates are written to an io.Writer, so if you want the result as a string, create and write to a bytes.Buffer (which implements io.Writer). Executing the template and getting the result as string:

            t := template.Must(template.New("email").Parse(emailTmpl))
            buf := &bytes.Buffer{}
            if err := t.Execute(buf, data); err != nil {
                panic(err)
            }
            s := buf.String()
            

            This will result in the expected output:

            Hi Bob!
            
            Your account is ready, your user name is: bob92
            
            You have the following roles assigned:
            dbteam, uiteam, tester
            

            Try it on the Go Playground.

            Note: you may also display the result of a template execution if you provide os.Stdout as the target (which also implements io.Writer):

            t := template.Must(template.New("email").Parse(emailTmpl))
            if err := t.Execute(os.Stdout, data); err != nil {
                panic(err)
            }
            

            This will write the result directly to os.Stdout. Try this on the Go Playground.

            posted on 2017-05-02 17:12 思月行云 閱讀(261) 評論(0)  編輯 收藏 引用 所屬分類: Golang
            欧美久久一级内射wwwwww.| 亚洲伊人久久综合中文成人网| 99久久这里只精品国产免费| 久久久一本精品99久久精品88| 久久亚洲私人国产精品| 91超碰碰碰碰久久久久久综合| 天天做夜夜做久久做狠狠| 久久w5ww成w人免费| 久久久久无码精品国产app| 欧美熟妇另类久久久久久不卡| 情人伊人久久综合亚洲| 久久亚洲精品无码VA大香大香| 久久久精品午夜免费不卡| 久久精品视频一| 精品久久久久久国产牛牛app| 日本五月天婷久久网站| 一级做a爱片久久毛片| 久久婷婷五月综合97色| 欧美一区二区久久精品| 久久丝袜精品中文字幕| 99久久精品这里只有精品| 精品国产一区二区三区久久久狼| 亚洲欧美一级久久精品| 精品久久久无码中文字幕| 国内精品久久久久久99| 人妻精品久久无码区| 亚洲中文字幕久久精品无码APP| 欧美激情精品久久久久久久九九九| 久久婷婷国产麻豆91天堂| 99精品国产综合久久久久五月天| 亚洲精品无码久久不卡| 中文字幕无码久久久| 亚洲精品tv久久久久| 一本久久精品一区二区| 99久久这里只精品国产免费| 无码国内精品久久综合88| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 久久国语露脸国产精品电影| 日韩亚洲国产综合久久久| 亚洲国产成人久久综合一区77 | 中文精品久久久久国产网址|