Golang 如何分割给定分隔符后的字节片
在Go语言中slice比数组更强大、灵活、方便,是一种轻量级的数据结构。slice是一个可变长度的序列,它可以存储相似类型的元素,你不允许在同一个slice中存储不同类型的元素。
在Go的字节片中,你可以使用SplitAfter()函数在指定的分隔符之后分割该片。这个函数将一个字节片在给定的分隔符的每个实例之后分割成所有子片,并返回一个包含这些子片的字节片。它被定义在字节包下,因此,你必须在你的程序中导入字节包以访问SplitAfter函数。
语法
func SplitAfter(o_slice, sep []byte) [][]byte
这里,o_slice是字节的片断,sep是分隔符。如果sep是空的,那么它将在每个UTF-8序列之后分割。让我们借助给定的例子来讨论这个概念。
例1 :
// Go program to illustrate the concept
// of splitting a slice of bytes
package main
import (
"bytes"
"fmt"
)
func main() {
// Creating and Splitting
// the slice of bytes
// Using SplitAfter function
res1 := bytes.SplitAfter([]byte("****Welcome, to, GeeksforGeeks****"),
[]byte(","))
res2 := bytes.SplitAfter([]byte("Learning x how x to x trim x a x slice of bytes"),
[]byte("x"))
res3 := bytes.SplitAfter([]byte("GeeksforGeeks, Geek"), []byte(""))
res4 := bytes.SplitAfter([]byte(""), []byte(","))
// Display the results
fmt.Printf("\nFinal Result after splitting:\n")
fmt.Printf("\nSlice 1: %s", res1)
fmt.Printf("\nSlice 2: %s", res2)
fmt.Printf("\nSlice 3: %s", res3)
fmt.Printf("\nSlice 4: %s", res4)
}
输出
Final Result after splitting:
Slice 1: [****Welcome, to, GeeksforGeeks****]
Slice 2: [Learning x how x to x trim x a x slice of bytes]
Slice 3: [G e e k s f o r G e e k s , G e e k]
Slice 4: []
例2 :
// Go program to illustrate the concept
// of splitting a slice of bytes
package main
import (
"bytes"
"fmt"
)
func main() {
// Creating and initializing
// the slice of bytes
// Using shorthand declaration
slice_1 := []byte{'!', '!', 'G', 'e', 'e', 'k', 's', 'f',
'o', 'r', 'G', 'e', 'e', 'k', 's', '#', '#'}
slice_2 := []byte{'A', 'p', 'p', 'l', 'e'}
slice_3 := []byte{'%', 'g', '%', 'e', '%',
'e', '%', 'k', '%', 's', '%'}
// Displaying slices
fmt.Println("Original Slice:")
fmt.Printf("Slice 1: %s", slice_1)
fmt.Printf("\nSlice 2: %s", slice_2)
fmt.Printf("\nSlice 3: %s", slice_3)
// Splitting the slice of bytes
// Using SplitAfter function
res1 := bytes.SplitAfter(slice_1, []byte("eek"))
res2 := bytes.SplitAfter(slice_2, []byte(""))
res3 := bytes.SplitAfter(slice_3, []byte("%"))
// Display the results
fmt.Printf("\n\nAfter splitting:\n")
fmt.Printf("\nSlice 1: %s", res1)
fmt.Printf("\nSlice 2: %s", res2)
fmt.Printf("\nSlice 3: %s", res3)
}
输出
Original Slice:
Slice 1: !!GeeksforGeeks##
Slice 2: Apple
Slice 3: %g%e%e%k%s%
After splitting:
Slice 1: [!!Geek sforGeek s##]
Slice 2: [A p p l e]
Slice 3: [% g% e% e% k% s% ]