• <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
            <2016年12月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567


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

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            相冊

            Awesome

            Blog

            Book

            GitHub

            Link

            搜索

            •  

            積分與排名

            • 積分 - 217529
            • 排名 - 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
            99久久中文字幕| 99999久久久久久亚洲| 欧美与黑人午夜性猛交久久久| 91精品免费久久久久久久久| 久久久久国产精品嫩草影院| 久久只这里是精品66| 日本欧美久久久久免费播放网| 久久精品无码一区二区无码| 国产精品内射久久久久欢欢| 国内精品伊人久久久久777| 国产91久久精品一区二区| 久久se精品一区精品二区国产 | 久久中文娱乐网| 久久无码一区二区三区少妇| 久久精品国产亚洲av水果派| 久久五月精品中文字幕| 天天综合久久久网| 一本色道久久99一综合| 久久艹国产| 久久99国产精品久久久 | 久久频这里精品99香蕉久| 丁香五月综合久久激情| 欧美一区二区三区久久综| 久久综合亚洲色一区二区三区| 久久婷婷久久一区二区三区| 精品无码久久久久国产动漫3d| 久久99热这里只有精品国产| 国产精品久久久久久| 久久精品国产亚洲av日韩| 国产aⅴ激情无码久久| 无码任你躁久久久久久久| 久久99精品久久久久久野外| 成人妇女免费播放久久久| 中文字幕热久久久久久久| 色综合合久久天天给综看| 久久精品国产亚洲av瑜伽| 国产精品丝袜久久久久久不卡| 97热久久免费频精品99| 国产精品一区二区久久 | 日批日出水久久亚洲精品tv| 久久涩综合|