Рубрики

Голанг | Разделение среза после указанного разделителя

В Go языковой фрагмент является более мощным, гибким, удобным, чем массив, и представляет собой облегченную структуру данных. Срез представляет собой последовательность переменной длины, в которой хранятся элементы аналогичного типа, вам не разрешено хранить элементы разного типа в одном и том же срезе.
В байтовом слайсе Go вы можете разделить слайс после указанного разделителя с помощью функции SplitAfterN () . Эта функция разбивает срез на все субликсы после каждого экземпляра данного разделителя и возвращает срез, который содержит эти субликсы. Если данный разделитель пуст, то он разделяется после каждой последовательности UTF-8, и счетчик указывает количество возвращаемых субликсов. Он определен в байтовом пакете, поэтому вам необходимо импортировать байтовый пакет в вашу программу для доступа к функции SplitAfterN.

Синтаксис:

func SplitAfterN(o_slice, sep []byte, m int) [][]byte

Здесь o_slice — исходная строка, sep — разделитель, а m используется для определения количества возвращаемых подстрок. Здесь, если m> 0 , то он возвращает не более m субликсов, и последний строковый сублис не будет разделен. Если m == 0 , то он вернет ноль. Если m <0 , он вернет все субликсы. Давайте обсудим эту концепцию с помощью приведенных примеров:

Пример 1:

// Перейти к программе, чтобы проиллюстрировать концепцию
// деления фрагмента байтов
package main 

     
import ( 

    "bytes"

    "fmt"

     
func main() { 

     

    // Создание и расщепление

    // часть байта

    // Использование функции SplitAfterN

    res1 := bytes.SplitAfterN([]byte("****Welcome, to, GeeksforGeeks****"), 

                                                           []byte(","), -1) 

         

    res2 := bytes.SplitAfterN([]byte("Learning x how x to x "+

                 "trim x a x slice of bytes"), []byte("x"), 3) 

         

    res3 := bytes.SplitAfterN([]byte("Geeks,for,Geeks, Geek"), []byte(","), 0) 

         

    res4 := bytes.SplitAfterN([]byte(""), []byte(","), 2) 

     

    // Показать результаты

    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: []
Slice 4: []

Пример 2:

// Перейти к программе, чтобы проиллюстрировать концепцию
// деления фрагмента байтов
package main 

     
import ( 

    "bytes"

    "fmt"

     
func main() { 

     

    // Создание и инициализация

    // часть байта

    // Использование стенографического объявления

    slice_1 := []byte{'!', '!', 'G', 'e', 'e', 'k', 's', 'f', 'o', 'r',

            'G', 'e', 'e', 'k', 's', 'G', 'e', 'e', 'k', 's', '#', '#'

         

    slice_2 := []byte{'A', 'p', 'p','p','p','l', 'e'

         

    slice_3 := []byte{'%', 'g', '%', 'e', '%',  

                 'e', '%', 'k', '%', 's', '%'

     

    // Отображение ломтиков

    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) 

     

    // Разделение фрагмента байтов

    // Использование функции SplitAfterN

    res1 := bytes.SplitAfterN(slice_1, []byte("eek"), 2) 

    res2 := bytes.SplitAfterN(slice_2, []byte(""), 3) 

    res3 := bytes.SplitAfterN(slice_3, []byte("%"), 0) 

     

    // Показать результаты

    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: !!GeeksforGeeksGeeks##
Slice 2: Apppple
Slice 3: %g%e%e%k%s%

After splitting:

Slice 1: [!!Geek sforGeeksGeeks##]
Slice 2: [A p ppple]
Slice 3: []

Рекомендуемые посты:

Голанг | Разделение среза после указанного разделителя

0.00 (0%) 0 votes