FMT标准库
标准库fmt提供了以下几种输出相关函数
Print系列函数会将内容输出到系统的标准输出,区别在于Print函数直接输出内容,Printf函数支持格式化输出字符串,Println函数会在输出内容的结尾添加一个换行符
通用占位符
| 占位符 | 说明 |
| %v | 值的默认格式表示 |
| %+v | 类似%v,但输出结构体时会添加字段名 |
| %#v | 值的go语法表示 |
| %T | 打印值的类型 |
| %% | 百分号 |
示例代码如下
package main
import (
"fmt"
)
func main() {
fmt.Printf("%v\n", 100)
fmt.Printf("%v\n", false)
o := make(map[string]int, 1)
o["wwww"] = 16
fmt.Printf("%v\n", o) //打印变量的值
fmt.Printf("%#V\n", o) //打印值和其go的类型
fmt.Printf("%T\n", o) //打印值的类型
fmt.Printf("100%%\n") //打印百分比
}
布尔型
| 占位符 | 说明 |
| %t | true或者false |
整形
| 占位符 | 说明 |
| %b | 表示为二进制 |
| %c | 该值对应的unicode码值 |
| %d | 表示为十进制 |
| %o | 表示为八进制 |
| %x | 表示为十六进制,使用a-f |
| %X | 表示为十六进制,使用A-F |
| %q | 该值对应的单引号括起来的go语法字符字面值,必要时会采用安全的转义标识 |
| %U | 表示为Unicode格式:U+1234,等价于“U+%o4X” |
浮点数和复数
| 占位符 | 说明 |
| %b | 无小数部分,二进制指数的科学计数法,如-123456p-78 |
| %e | 科学计数法,如-1234.345e+78 |
| %E | 科学计数法,如-1234.456E+78 |
| %f | 有小数部分但无指数部分,如123456 |
| %F | 等价于%f |
| %g | 根据实际情况采用%e或%f格式(以获得更简洁,准确的输出) |
| %G | 根据实际情况采用%E或%F格式(以获得更简洁,准确的输出) |
字符串和[]byte
| 占位符 | 说明 |
| %s | 直接输出字符串或者[]byte |
| %q | 该值对应的双引号括起来的go语法字符串表面值,必要时会采用安全的转义表示 |
| %x | 每个字节用两字符十六进制数表示, 使用a-f |
| %X | 每个字节用两字符十六进制数表示,使用A-F |
获取输入
go语言fmt包下有fmt.Scan、fmt.Scanf、fmt.Scanln三个函数,可以在程序运行过程中从标准输入获取用户的输入。
func.Scan
函数定签名如下:
func Scan(a ...interface{}) (n int,err error)
- Scan从标准输入扫描文本,读取由空白字符分隔的值保存到传递给本函数的参数中,换行符视为空白符。
- 本函数返回成功扫描的数据个数和遇到的任何错误。如果读取的数据个数比提供的参数超,会返回一个错误报告原因
Scan
package main
import (
"fmt"
)
func main() {
var s string
fmt.Scan(&s) //此处需要在终端输入字符串
fmt.Println(s)
}
Scanf
package main
import (
"fmt"
)
func main() {
var (
name string
age int
class string
)
fmt.Scanf("%s %d %s\n", &name, &age, &class) //此处输入的内容需要以空格为分界来输入
fmt.Println(name, age, class)
}
Scanln
package main
import (
"fmt"
)
func main() {
var (
name string
age int
class string
)
fmt.Scanln(&name, &age, &class) //此处输入的内容需要以空格为分界来输入
fmt.Println(name, age, class)
}

浙公网安备 33010602011771号