print readable variables with golang

huangapple go评论96阅读模式
英文:

print readable variables with golang

问题

如何以可读的方式打印地图、结构或其他内容?

使用PHP,你可以这样做:

  1. echo '<pre>';
  2. print_r($var);
  3. echo '</pre>';

或者

  1. header('content-type: text/plain');
  2. print_r($var);
英文:

How to print a map, struct or whatever in a readable way?

With PHP you can to this

  1. echo &#39;&lt;pre&gt;&#39;;
  2. print_r($var);
  3. echo &#39;&lt;/pre&gt;&#39;;

or

  1. header(&#39;content-type: text/plain&#39;);
  2. print_r($var);

答案1

得分: 19

使用Go的fmt包。例如,

  1. package main
  2. import "fmt"
  3. func main() {
  4. variable := "var"
  5. fmt.Println(variable)
  6. fmt.Printf("%#v\n", variable)
  7. header := map[string]string{"content-type": "text/plain"}
  8. fmt.Println(header)
  9. fmt.Printf("%#v\n", header)
  10. }

输出:

  1. var
  2. "var"
  3. map[content-type:text/plain]
  4. map[string]string{"content-type":"text/plain"}

> fmt包
>
> import "fmt"
>
> 概述
>
> 包fmt实现了类似于C的printf和scanf的格式化I/O。格式化的“动词”源自C,但更简单。

英文:

Use the Go fmt package. For example,

  1. package main
  2. import &quot;fmt&quot;
  3. func main() {
  4. variable := &quot;var&quot;
  5. fmt.Println(variable)
  6. fmt.Printf(&quot;%#v\n&quot;, variable)
  7. header := map[string]string{&quot;content-type&quot;: &quot;text/plain&quot;}
  8. fmt.Println(header)
  9. fmt.Printf(&quot;%#v\n&quot;, header)
  10. }

Output:

  1. var
  2. &quot;var&quot;
  3. map[content-type:text/plain]
  4. map[string]string{&quot;content-type&quot;:&quot;text/plain&quot;}

> Package fmt
>
> import "fmt"
>
> Overview
>
> Package fmt implements formatted I/O with functions analogous to C's
> printf and scanf. The format 'verbs' are derived from C's but are
> simpler.

答案2

得分: 15

我认为在许多情况下,使用"%v"已经足够简洁了:

  1. fmt.Printf("%v", myVar)

根据fmt包的文档页面:

  • %v:以默认格式打印值。当打印结构体时,加号标志(%+v)会添加字段名。
  • %#v:以Go语法表示的值的表示形式。

以下是一个示例:

  1. package main
  2. import "fmt"
  3. func main() {
  4. // 定义一个结构体、切片和映射
  5. type Employee struct {
  6. id int
  7. name string
  8. age int
  9. }
  10. var eSlice []Employee
  11. var eMap map[int]Employee
  12. e1 := Employee{1, "Alex", 20}
  13. e2 := Employee{2, "Jack", 30}
  14. fmt.Printf("%v\n", e1)
  15. // 输出:{1 Alex 20}
  16. fmt.Printf("%+v\n", e1)
  17. // 输出:{id:1 name:Alex age:20}
  18. fmt.Printf("%#v\n", e1)
  19. // 输出:main.Employee{id:1, name:"Alex", age:20}
  20. eSlice = append(eSlice, e1, e2)
  21. fmt.Printf("%v\n", eSlice)
  22. // 输出:[{1 Alex 20} {2 Jack 30}]
  23. fmt.Printf("%#v\n", eSlice)
  24. // 输出:[]main.Employee{main.Employee{id:1, name:"Alex", age:20}, main.Employee{id:2, name:"Jack", age:30}}
  25. eMap = make(map[int]Employee)
  26. eMap[1] = e1
  27. eMap[2] = e2
  28. fmt.Printf("%v\n", eMap)
  29. // 输出:map[1:{1 Alex 20} 2:{2 Jack 30}]
  30. fmt.Printf("%#v\n", eMap)
  31. // 输出:map[int]main.Employee{1:main.Employee{id:1, name:"Alex", age:20}, 2:main.Employee{id:2, name:"Jack", age:30}}
  32. }
英文:

I think in many cases, using "%v" is concise enough:

  1. fmt.Printf(&quot;%v&quot;, myVar)

From the fmt package's documentation page:

> %v the value in a default format.
> when printing structs, the plus flag (%+v) adds field names
>
> %#v a Go-syntax representation of the value

Here is an example:

  1. package main
  2. import &quot;fmt&quot;
  3. func main() {
  4. // Define a struct, slice and map
  5. type Employee struct {
  6. id int
  7. name string
  8. age int
  9. }
  10. var eSlice []Employee
  11. var eMap map[int]Employee
  12. e1 := Employee{1, &quot;Alex&quot;, 20}
  13. e2 := Employee{2, &quot;Jack&quot;, 30}
  14. fmt.Printf(&quot;%v\n&quot;, e1)
  15. // output: {1 Alex 20}
  16. fmt.Printf(&quot;%+v\n&quot;, e1)
  17. // output: {id:1 name:Alex age:20}
  18. fmt.Printf(&quot;%#v\n&quot;, e1)
  19. // output: main.Employee{id:1, name:&quot;Alex&quot;, age:20}
  20. eSlice = append(eSlice, e1, e2)
  21. fmt.Printf(&quot;%v\n&quot;, eSlice)
  22. // output: [{1 Alex 20} {2 Jack 30}]
  23. fmt.Printf(&quot;%#v\n&quot;, eSlice)
  24. // output: []main.Employee{main.Employee{id:1, name:&quot;Alex&quot;, age:20}, main.Employee{id:2, name:&quot;Jack&quot;, age:30}}
  25. eMap = make(map[int]Employee)
  26. eMap[1] = e1
  27. eMap[2] = e2
  28. fmt.Printf(&quot;%v\n&quot;, eMap)
  29. // output: map[1:{1 Alex 20} 2:{2 Jack 30}]
  30. fmt.Printf(&quot;%#v\n&quot;, eMap)
  31. // output: map[int]main.Employee{1:main.Employee{id:1, name:&quot;Alex&quot;, age:20}, 2:main.Employee{id:2, name:&quot;Jack&quot;, age:30}}
  32. }

答案3

得分: 5

你可以使用fmt.Println()来打印输出。你需要导入"fmt"包(参见下面的示例)。许多数据类型可以直接打印输出。如果你想要为自定义类型获得可读性强的打印输出,你需要为该类型定义一个String() string方法。

要尝试下面的示例,请点击这里:http://play.golang.org/p/M6_KnRJ3Da

  1. package main
  2. import "fmt"
  3. // 没有`String()`方法
  4. type UnstringablePerson struct {
  5. Age int
  6. Name string
  7. }
  8. // 有`String()`方法
  9. type StringablePerson struct {
  10. Age int
  11. Name string
  12. }
  13. // 让我们为StringablePerson定义一个String()方法,这样任何StringablePerson的实例都可以按我们喜欢的方式打印出来
  14. func (p *StringablePerson) String() string {
  15. return fmt.Sprintf("%s, age %d", p.Name, p.Age)
  16. }
  17. func main() {
  18. // Bobby的类型是UnstringablePerson;对于这种类型,没有定义String()方法,所以他的打印输出不太友好
  19. bobby := &UnstringablePerson{
  20. Age: 10,
  21. Name: "Bobby",
  22. }
  23. // Ralph的类型是StringablePerson;对于这种类型,*有*定义String()方法,所以他的打印输出*会*很友好
  24. ralph := &StringablePerson{
  25. Age: 12,
  26. Name: "Ralph",
  27. }
  28. fmt.Println(bobby) // 输出:&{10 Bobby}
  29. fmt.Println(ralph) // 输出:Ralph, age 12
  30. }
英文:

You can use fmt.Println() to print. You will need to import the "fmt" package (see the example below). Many data types can be printed out of the box. If you want to get a human-readable print for custom types, you'll need to define a String() string method for that type.

To try the following example, click here: http://play.golang.org/p/M6_KnRJ3Da

  1. package main
  2. import &quot;fmt&quot;
  3. // No `String()` method
  4. type UnstringablePerson struct {
  5. Age int
  6. Name string
  7. }
  8. // Has a `String()` method
  9. type StringablePerson struct {
  10. Age int
  11. Name string
  12. }
  13. // Let&#39;s define a String() method for StringablePerson, so any instances
  14. // of StringablePerson can be printed how we like
  15. func (p *StringablePerson) String() string {
  16. return fmt.Sprintf(&quot;%s, age %d&quot;, p.Name, p.Age)
  17. }
  18. func main() {
  19. // Bobby&#39;s type is UnstringablePerson; there is no String() method
  20. // defined for this type, so his printout will not be very friendly
  21. bobby := &amp;UnstringablePerson{
  22. Age: 10,
  23. Name: &quot;Bobby&quot;,
  24. }
  25. // Ralph&#39;s type is StringablePerson; there *is* a String() method
  26. // defined for this type, so his printout *will* be very friendly
  27. ralph := &amp;StringablePerson{
  28. Age: 12,
  29. Name: &quot;Ralph&quot;,
  30. }
  31. fmt.Println(bobby) // prints: &amp;{10 Bobby}
  32. fmt.Println(ralph) // prints: Ralph, age 12
  33. }

答案4

得分: 3

go-spew是一个用于Go数据结构的深度漂亮打印机,以帮助调试。你可以在https://github.com/davecgh/go-spew找到它。

英文:

https://github.com/davecgh/go-spew

> Go-spew implements a deep pretty printer for Go data structures to aid in debugging.

答案5

得分: 2

你好!以下是翻译好的内容:

  1. fmt.Printf("%v", whatever)

在Go语言中,这类似于PHP中的print_r()、var_dump()和var_export()函数。(%v是其中重要的部分。)

祝你好运!

英文:
  1. fmt.Printf(&quot;%v&quot;, whatever)

In Go is like print_r(), var_dump(), var_export() in PHP. (The %v is the important part.)

Good Luck

答案6

得分: 1

用于调试的代码如下:

  1. func printVars(w io.Writer, writePre bool, vars ...interface{}) {
  2. if writePre {
  3. io.WriteString(w, "<pre>\n")
  4. }
  5. for i, v := range vars {
  6. fmt.Fprintf(w, "» item %d type %T:\n", i, v)
  7. j, err := json.MarshalIndent(v, "", " ")
  8. switch {
  9. case err != nil:
  10. fmt.Fprintf(w, "error: %v", err)
  11. case len(j) < 3: // {}, empty struct maybe or empty string, usually mean unexported struct fields
  12. w.Write([]byte(html.EscapeString(fmt.Sprintf("%+v", v))))
  13. default:
  14. w.Write(j)
  15. }
  16. w.Write([]byte("\n\n"))
  17. }
  18. if writePre {
  19. io.WriteString(w, "</pre>\n")
  20. }
  21. }

[kbd]playground/kbd

英文:

For debugging I use this:

  1. func printVars(w io.Writer, writePre bool, vars ...interface{}) {
  2. if writePre {
  3. io.WriteString(w, &quot;&lt;pre&gt;\n&quot;)
  4. }
  5. for i, v := range vars {
  6. fmt.Fprintf(w, &quot;&#187; item %d type %T:\n&quot;, i, v)
  7. j, err := json.MarshalIndent(v, &quot;&quot;, &quot; &quot;)
  8. switch {
  9. case err != nil:
  10. fmt.Fprintf(w, &quot;error: %v&quot;, err)
  11. case len(j) &lt; 3: // {}, empty struct maybe or empty string, usually mean unexported struct fields
  12. w.Write([]byte(html.EscapeString(fmt.Sprintf(&quot;%+v&quot;, v))))
  13. default:
  14. w.Write(j)
  15. }
  16. w.Write([]byte(&quot;\n\n&quot;))
  17. }
  18. if writePre {
  19. io.WriteString(w, &quot;&lt;/pre&gt;\n&quot;)
  20. }
  21. }

<kbd>playground</kbd>

huangapple
  • 本文由 发表于 2014年9月26日 01:59:20
  • 转载请务必保留本文链接:https://go.coder-hub.com/26045106.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定