lin
2025-06-05 ed3dd9d3e7519a82bb871d5eedb24a2fa0c91f47
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
// Copyright 2013 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
 
package bufio_test
 
import (
   "bufio"
   "fmt"
   "os"
   "strconv"
   "strings"
)
 
func ExampleWriter() {
   w := bufio.NewWriter(os.Stdout)
   fmt.Fprint(w, "Hello, ")
   fmt.Fprint(w, "world!")
   w.Flush() // Don't forget to flush!
   // Output: Hello, world!
}
 
// The simplest use of a Scanner, to read standard input as a set of lines.
func ExampleScanner_lines() {
   scanner := bufio.NewScanner(os.Stdin)
   for scanner.Scan() {
       fmt.Println(scanner.Text()) // Println will add back the final '\n'
   }
   if err := scanner.Err(); err != nil {
       fmt.Fprintln(os.Stderr, "reading standard input:", err)
   }
}
 
// Use a Scanner to implement a simple word-count utility by scanning the
// input as a sequence of space-delimited tokens.
func ExampleScanner_words() {
   // An artificial input source.
   const input = "Now is the winter of our discontent,\nMade glorious summer by this sun of York.\n"
   scanner := bufio.NewScanner(strings.NewReader(input))
   // Set the split function for the scanning operation.
   scanner.Split(bufio.ScanWords)
   // Count the words.
   count := 0
   for scanner.Scan() {
       count++
   }
   if err := scanner.Err(); err != nil {
       fmt.Fprintln(os.Stderr, "reading input:", err)
   }
   fmt.Printf("%d\n", count)
   // Output: 15
}
 
// Use a Scanner with a custom split function (built by wrapping ScanWords) to validate
// 32-bit decimal input.
func ExampleScanner_custom() {
   // An artificial input source.
   const input = "1234 5678 1234567901234567890"
   scanner := bufio.NewScanner(strings.NewReader(input))
   // Create a custom split function by wrapping the existing ScanWords function.
   split := func(data []byte, atEOF bool) (advance int, token []byte, err error) {
       advance, token, err = bufio.ScanWords(data, atEOF)
       if err == nil && token != nil {
           _, err = strconv.ParseInt(string(token), 10, 32)
       }
       return
   }
   // Set the split function for the scanning operation.
   scanner.Split(split)
   // Validate the input
   for scanner.Scan() {
       fmt.Printf("%s\n", scanner.Text())
   }
 
   if err := scanner.Err(); err != nil {
       fmt.Printf("Invalid input: %s", err)
   }
   // Output:
   // 1234
   // 5678
   // Invalid input: strconv.ParseInt: parsing "1234567901234567890": value out of range
}
 
// Use a Scanner with a custom split function to parse a comma-separated
// list with an empty final value.
func ExampleScanner_emptyFinalToken() {
   // Comma-separated list; last entry is empty.
   const input = "1,2,3,4,"
   scanner := bufio.NewScanner(strings.NewReader(input))
   // Define a split function that separates on commas.
   onComma := func(data []byte, atEOF bool) (advance int, token []byte, err error) {
       for i := 0; i < len(data); i++ {
           if data[i] == ',' {
               return i + 1, data[:i], nil
           }
       }
       // There is one final token to be delivered, which may be the empty string.
       // Returning bufio.ErrFinalToken here tells Scan there are no more tokens after this
       // but does not trigger an error to be returned from Scan itself.
       return 0, data, bufio.ErrFinalToken
   }
   scanner.Split(onComma)
   // Scan.
   for scanner.Scan() {
       fmt.Printf("%q ", scanner.Text())
   }
   if err := scanner.Err(); err != nil {
       fmt.Fprintln(os.Stderr, "reading input:", err)
   }
   // Output: "1" "2" "3" "4" ""
}