3 回答
TA贡献1820条经验 获得超2个赞
例如,
package main
import (
"fmt"
"strings"
)
func pairs(s string) []string {
var p []string
fs := strings.Fields(s)
if len(fs) >= 2 {
p = make([]string, 0, len(fs)-1)
for i, f := range fs[1:len(fs)] {
p = append(p, fs[i]+" "+f)
}
}
return p
}
func main() {
s := "aa bb cc dd ee ff"
fmt.Printf("%q\n", s)
p := pairs(s)
fmt.Printf("%q\n", p)
}
输出:
"aa bb cc dd ee ff"
["aa bb" "bb cc" "cc dd" "dd ee" "ee ff"]
TA贡献1816条经验 获得超4个赞
你可以用一个迭代bufio.Scanner:
package main
import (
"bufio"
"strings"
)
func abc(data []byte, eof bool) (int, []byte, error) {
if eof {
return 0, nil, nil
}
a := -1
for b, c := range data {
if c == ' ' {
if a >= 0 {
return a+1, data[:b], nil
}
a = b
}
}
return len(data), data, nil
}
func main() {
s := bufio.NewScanner(strings.NewReader("aa bb cc dd ee ff"))
s.Split(abc)
for s.Scan() {
println(s.Text())
}
}
https://golang.org/pkg/bufio#Scanner.Split
- 3 回答
- 0 关注
- 191 浏览
添加回答
举报