【发布时间】:2021-05-27 00:27:32
【问题描述】:
如果我想扫描一个字符串,我可以这样做:
package main
import (
"fmt"
"strings"
)
func main() {
r := strings.NewReader("west north east")
for {
var s string
_, e := fmt.Fscan(r, &s)
fmt.Printf("%q %v\n", s, e)
if e != nil { break }
}
}
结果:
"west" <nil>
"north" <nil>
"east" <nil>
"" EOF
我最近发现fmt.Scanner[1],所以我想我会尝试实现
它。我想出了这个:
package main
import (
"fmt"
"strings"
)
type comma struct { tok string }
func (c *comma) Scan(state fmt.ScanState, verb rune) error {
tok, err := state.Token(false, func(r rune) bool {
return r != ','
})
if err != nil {
return err
}
if _, _, err := state.ReadRune(); err != nil {
if len(tok) == 0 {
return err
}
}
c.tok = string(tok)
return nil
}
func main() {
r := strings.NewReader("west,north,east")
for {
var c comma
_, e := fmt.Fscan(r, &c)
fmt.Printf("%q %v\n", c.tok, e)
if e != nil { break }
}
}
结果:
"west" <nil>
"north" <nil>
"east" <nil>
"" unexpected EOF
所以结果非常接近,但困扰我的是unexpected EOF。是
是否可以通过自定义fmt.Scanner 获得常规EOF?我在做吗
这里有问题,还是这是一个错误?
【问题讨论】:
-
我认为在当前版本的 Go 中是不可能的。见:golang.org/src/fmt/scan.go?s=2653:2699#L961