博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
go标准库的学习-fmt
阅读量:6279 次
发布时间:2019-06-22

本文共 10061 字,大约阅读时间需要 33 分钟。

参考https://studygolang.com/pkgdoc

导入方式:

import "fmt"

mt包实现了类似C语言printf和scanf的格式化I/O。格式化动作('verb')源自C语言但更简单。

func Printf

func Printf(format string, a ...interface{}) (n int, err error)

Printf根据format参数生成格式化的字符串并写入标准输出os.stdout。返回写入的字节数和遇到的任何错误。

func Fprintf

func Fprintf(w io.Writer, format string, a ...interface{}) (n int, err error)

Fprintf根据format参数生成格式化的字符串并写入w。返回写入的字节数和遇到的任何错误。

func Sprintf

func Sprintf(format string, a ...interface{}) string

Sprintf根据format参数生成格式化的字符串并返回该字符串。

func Print

func Print(a ...interface{}) (n int, err error)

Print采用默认格式将其参数格式化并写入标准输出。如果两个相邻的参数都不是字符串,会在它们的输出之间添加空格。返回写入的字节数和遇到的任何错误。

func Fprint

func Fprint(w io.Writer, a ...interface{}) (n int, err error)

Fprint采用默认格式将其参数格式化并写入w。如果两个相邻的参数都不是字符串,会在它们的输出之间添加空格。返回写入的字节数和遇到的任何错误。

func Sprint

func Sprint(a ...interface{}) string

Sprint采用默认格式将其参数格式化,串联所有输出生成并返回一个字符串。如果两个相邻的参数都不是字符串,会在它们的输出之间添加空格。

func Println

func Println(a ...interface{}) (n int, err error)

Println采用默认格式将其参数格式化并写入标准输出。总是会在相邻参数的输出之间添加空格并在输出结束后添加换行符。返回写入的字节数和遇到的任何错误。

func Fprintln

func Fprintln(w io.Writer, a ...interface{}) (n int, err error)

Fprintln采用默认格式将其参数格式化并写入w。总是会在相邻参数的输出之间添加空格并在输出结束后添加换行符。返回写入的字节数和遇到的任何错误。

func Sprintln

func Sprintln(a ...interface{}) string

Sprintln采用默认格式将其参数格式化,串联所有输出生成并返回一个字符串。总是会在相邻参数的输出之间添加空格并在输出结束后添加换行符。

func Errorf

func Errorf(format string, a ...interface{}) error

Errorf根据format参数生成格式化字符串并返回一个包含该字符串的错误。

举例:

package main import(    "fmt"    "os"    "log"    "bufio")func main() {    fmt.Printf("right now is try to test %s, this is the %dst time to test fmt\n", "Printf", 1)    writer := bufio.NewWriter(os.Stdout)    fmt.Fprintf(writer, "right now is try to test %s, this is the %dst time to test fmt\n", "Fprintf", 2)//等价于直接使用Printf,因为指定将值输出到标准输出    writer.Flush()    file, err := os.Create("testFmt.txt")    if err != nil {        log.Fatal(err)    }    defer file.Close()    writer1 := bufio.NewWriter(file)    _, err = fmt.Fprintf(writer1, "right now is try to test %s, this is the %dst time to test fmt\n", "Fprintf", 3)    if err != nil {        log.Fatal(err)    }    prompt := "right now is try to test %s, this is the %dst time to test fmt"    prompt = fmt.Sprintf(prompt, "Sprintf", 4)    //串联输入的字符串参数,如果并不是都是字符串,则用空格将其分隔    fmt.Println(prompt)    fmt.Print(prompt, "\n") //两者的区别在于Println会自动换行,而Print不会    //串联所有输出生成并返回一个字符串。如果两个相邻的参数都不是字符串,会在它们的输出之间添加空格    prompt1 := fmt.Sprint("right now is try to test", "Sprint", ", this is the ", 5, "st time to test fmt")    fmt.Println(prompt1)    fmt.Fprintln(writer1, "right now is try to test", "Fprintln", ", this is the ", 6, "st time to test fmt")    writer1.Flush()    prompt2 := fmt.Sprintln("right now is try to test", "Sprintln", ", this is the ", 7, "st time to test fmt")    fmt.Println(prompt2)    err = fmt.Errorf("test how to use %s to generate an err info", "Errorf")    if err != nil {        log.Fatal(err)    }}

返回:

bogon:go-learning user$ go run test.goright now is try to test Printf, this is the 1st time to test fmtright now is try to test Fprintf, this is the 2st time to test fmtright now is try to test Sprintf, this is the 4st time to test fmtright now is try to test Sprintf, this is the 4st time to test fmtright now is try to testSprint, this is the 5st time to test fmtright now is try to test Sprintln , this is the  7 st time to test fmt2019/01/27 12:34:01 test how to use Errorf to generate an err infoexit status 1

然后对应的testFmt.txt中的输出是:

 

right now is try to test Fprintf, this is the 3st time to test fmtright now is try to test Fprintln , this is the  6 st time to test fmt

 

 

 

Scanning 

一系列类似的函数可以扫描格式化文本以生成值。

Scan、Scanf和Scanln从标准输入os.Stdin读取文本;Fscan、Fscanf、Fscanln从指定的io.Reader接口读取文本;Sscan、Sscanf、Sscanln从一个参数字符串读取文本。

Scanln、Fscanln、Sscanln会在读取到换行时停止,并要求一次提供一行所有条目;Scanf、Fscanf、Sscanf只有在格式化文本末端有换行时会读取到换行为止;其他函数会将换行视为空白。

Scanf、Fscanf、Sscanf会根据格式字符串解析参数,类似Printf。例如%x会读取一个十六进制的整数,%v会按对应值的默认格式读取。格式规则类似Printf,有如下区别:

%p 未实现%T 未实现%e %E %f %F %g %G 效果相同,用于读取浮点数或复数类型%s %v 用在字符串时会读取空白分隔的一个片段flag '#'和'+' 未实现

在无格式化verb或verb %v下扫描整数时会接受常用的进制设置前缀0(八进制)和0x(十六进制)。

宽度会在输入文本中被使用(%5s表示最多读取5个rune来生成一个字符串),但没有使用精度的语法(没有%5.2f,只有%5f)。

当使用格式字符串进行扫描时,多个连续的空白字符(除了换行符)在输出和输出中都被等价于一个空白符。在此前提下,格式字符串中的文本必须匹配输入的文本;如果不匹配扫描会中止,函数的整数返回值说明已经扫描并填写的参数个数。

在所有的扫描函数里,\r\n都被视为\n。

在所有的扫描函数里,如果一个操作数实现了Scan方法(或者说,它实现了Scanner接口),将会使用该接口为该操作数扫描文本。另外,如果如果扫描到(准备填写)的参数比提供的参数个数少,会返回一个错误。

提供的所有参数必须为指针或者实现了Scanner接口。注意:Fscan等函数可能会在返回前多读取一个rune,这导致多次调用这些函数时可能会跳过部分输入。只有在输入里各值之间没有空白时,会出现问题。如果提供给Fscan等函数的io.Reader接口实现了ReadRune方法,将使用该方法读取字符。如果该io.Reader接口还实现了UnreadRune方法,将是使用该方法保存字符,这样可以使成功执行的Fscan等函数不会丢失数据。

如果要给一个没有这两个方法的io.Reader接口提供这两个方法,使用bufio.NewReader。

 

func Scan

func Scan(a ...interface{}) (n int, err error)

Scan从标准输入扫描文本,将成功读取的空白分隔的值保存进成功传递给本函数的参数。换行视为空白。返回成功扫描的条目个数和遇到的任何错误。如果读取的条目比提供的参数少,会返回一个错误报告原因。

举例:

package main import(    "fmt"    "log")func main() {    fmt.Println("enter two parameter : ")    var param1, param2 string    n, err := fmt.Scan(&param1, &param2)    if err != nil{        log.Fatal(err)    }    fmt.Println(param1, param2, n)}

返回:

bogon:go-learning user$ go run test.goenter two parameter : test scantest scan 2

func Scanln

func Scanln(a ...interface{}) (n int, err error)

Scanln类似Scan,但会在换行时才停止扫描。最后一个条目后必须有换行或者到达结束位置。

举例:

package main import(    "fmt"    "log")func main() {    fmt.Println("enter two parameter : ")    var param1, param2 string    n, err := fmt.Scanln(&param1, &param2)    if err != nil{        log.Fatal(err)    }    fmt.Println(param1, param2, n)}

返回:

bogon:go-learning user$ go run test.goenter two parameter : test scanlntest scanln 2

func Scanf

func Scanf(format string, a ...interface{}) (n int, err error)

Scanf从标准输入扫描文本,根据format 参数指定的格式将成功读取的空白分隔的值保存进成功传递给本函数的参数。返回成功扫描的条目个数和遇到的任何错误。

举例:

package main import(    "fmt"    // "os"    // "bufio"    "log")func main() {    fmt.Println("enter two float parameter : ")    var param1, param2 float64    // n, err := fmt.Scanf("%.2f %.2f", &param1, &param2)//会返回错误 2019/01/27 14:15:20 bad verb '%.' for float32,因为scan不支持精度    // n, err := fmt.Scanf("%f %f", &param1, &param2)//只能设置宽度,精度默认为2,%5s表示最多读取5个rune来生成一个字符串    //返回    // enter two float parameter :     // 3.456 2345.6    // 3.45 2345.6 2    n, err := fmt.Scanf("%4f %7f", &param1, &param2)//只能设置宽度,%4f表示你的输入包括小数点只能有4位,多余部分被舍弃或被下一个格式化获取    if err != nil{
//如果第一个输入值大于4位,那么就会报错 expected space in input to match format,因为下一个得到的不是空格,而是一个多余数值 log.Fatal(err) } // 返回: // enter two float parameter : // 3.45 2345.6 // 3.45 2345.6 2 fmt.Println(param1, param2, n)}

 

 func Fscan

func Fscan(r io.Reader, a ...interface{}) (n int, err error)

Fscan从r扫描文本,将成功读取的空白分隔的值保存进成功传递给本函数的参数。换行视为空白。返回成功扫描的条目个数和遇到的任何错误。如果读取的条目比提供的参数少,会返回一个错误报告原因。

举例:

package main import(    "fmt"    "os"    "bufio"    "log")func main() {    file, err :=os.Open("testFscan.txt")    if err != nil{        log.Fatal(err)    }    defer file.Close()    reader := bufio.NewReader(file)    fmt.Println("read the content of testFscan.txt: ")    var param1, param2 string    n, err := fmt.Fscan(reader, &param1, &param2)    if err != nil{        log.Fatal(err)    }    fmt.Println(param1, param2, n)}

testFscan.txt的内容是:

 

Right now is trying to test FscanThis is the end!!

 

返回:

userdeMBP:go-learning user$ go run test.goread the content of testFscan.txt: Right now 2

因为他是以空格为分隔的

 

func Fscanln

func Fscanln(r io.Reader, a ...interface{}) (n int, err error)

Fscanln类似Fscan,但会在换行时才停止扫描。最后一个条目后必须有换行或者到达结束位置。

举例:

package main import(    "fmt"    "strings"    "log"    "io")func main() {    str := `Fscanln 1 34.5677     test 2 3243.53`    reader := strings.NewReader(str)    var param1 string    var param2 int    var param3 float64    for{        n, err := fmt.Fscanln(reader, &param1, &param2, &param3)        if err != nil {            if err == io.EOF {                break            }            log.Fatal(err)        }        fmt.Printf("%d : %s, %d, %f\n", n, param1, param2, param3)    }}

返回:

userdeMBP:go-learning user$ go run test.go3 : Fscanln, 1, 34.5677003 : test, 2, 3243.530000

func Fscanf

func Fscanf(r io.Reader, format string, a ...interface{}) (n int, err error)

Fscanf从r扫描文本,根据format 参数指定的格式将成功读取的空白分隔的值保存进成功传递给本函数的参数。返回成功扫描的条目个数和遇到的任何错误。

举例:

package main import(    "fmt"    "strings"    "log")func main() {    // str := `Fscanln 1 34.5677  //不能使用这种书写方式,因为遇见换行符会报错 unexpected newline    // test 2 3243.53`    str := "Fscanln 1 34.5677"    reader := strings.NewReader(str)    var(        param1 string        param2 int        param3 float64    )    n, err := fmt.Fscanf(reader, "%s %d %f", &param1, &param2, &param3)    if err != nil {        log.Fatal(err)    }    fmt.Println( n, param1, param2, param3)}

返回:

userdeMBP:go-learning user$ go run test.go3 Fscanln 1 34.5677

func Sscan

func Sscan(str string, a ...interface{}) (n int, err error)

Sscan从字符串str扫描文本,将成功读取的空白分隔的值保存进成功传递给本函数的参数。换行视为空白。返回成功扫描的条目个数和遇到的任何错误。如果读取的条目比提供的参数少,会返回一个错误报告原因。

举例:

package main import(    "fmt"    "log")func main() {    var(        param1 string        param2 int        param3 float64    )    n, err := fmt.Sscan("Fscanln 1 34.5677", &param1, &param2, &param3)    if err != nil {        log.Fatal(err)    }    fmt.Println( n, param1, param2, param3)//返回 3 Fscanln 1 34.5677}

func Sscanln

func Sscanln(str string, a ...interface{}) (n int, err error)

Sscanln类似Sscan,但会在换行时才停止扫描。最后一个条目后必须有换行或者到达结束位置

和Sscan相似,就不举例了,注意:

作为Sscan和Sscanln的string参数的值不能是:

str := `Fscanln 1 34.5677    test 2 3243.53`

因为他不是reader,没有指针指向上次读取的地方,因此每一次读取都会从string的头开始,然后读到换行符就会停止,这样就不会读取到第二行 test 2 3243.53 的值

func Sscanf

func Sscanf(str string, format string, a ...interface{}) (n int, err error)

Sscanf从字符串str扫描文本,根据format 参数指定的格式将成功读取的空白分隔的值保存进成功传递给本函数的参数。返回成功扫描的条目个数和遇到的任何错误。

举例:

package main import(    "fmt"    "log")func main() {    var(        param1 string        param2 int        param3 float64    )    n, err := fmt.Sscanf("Fscanln 1 34.5677", "%s %d %f", &param1, &param2, &param3)    if err != nil {        log.Fatal(err)    }    fmt.Println( n, param1, param2, param3)}

返回:

userdeMBP:go-learning user$ go run test.go3 Fscanln 1 34.5677

 

转载于:https://www.cnblogs.com/wanghui-garcia/p/10326395.html

你可能感兴趣的文章
大佬是怎么思考设计MySQL优化方案的?
查看>>
<三体> 给岁月以文明, 给时光以生命
查看>>
Android开发 - 掌握ConstraintLayout(九)分组(Group)
查看>>
springboot+logback日志异步数据库
查看>>
Typescript教程之函数
查看>>
Android 高效安全加载图片
查看>>
vue中数组变动不被监测问题
查看>>
3.31
查看>>
类对象定义 二
查看>>
收费视频网站Netflix:用户到底想要“点”什么?
查看>>
MacOS High Sierra 12 13系统转dmg格式
查看>>
关于再次查看已做的多选题状态逻辑问题
查看>>
动态下拉菜单,非hover
查看>>
政府安全资讯精选 2017年第十六期 工信部发布关于规范互联网信息服务使用域名的通知;俄罗斯拟建立备用DNS;Google打击安卓应用在未经同意情况下收集个人信...
查看>>
简单易懂的谈谈 javascript 中的继承
查看>>
多线程基础知识
查看>>
iOS汇编基础(四)指针和macho文件
查看>>
Laravel 技巧锦集
查看>>
Android 使用 ViewPager+RecyclerView+SmartRefreshLayout 实现顶部图片下拉视差效果
查看>>
Flutter之基础Widget
查看>>