如何在 Go 中處理 String

閱讀時間約 20 分鐘


raw-image

👨‍💻 簡介

一開始介紹基本資料型別時有稍微提到一點string的處理,今天介紹string的一些操作,像是檢查的功能、修改的功能、比較的功能等等。

檢查功能

  • strings.Contains:檢查一個string是否包含另一個string。
  • strings.ContainsAny:檢查一個string是否包含任何指定的Unicode字元。
  • strings.Count:計算subString在目標string中出現的次數。
  • strings.ContainsRune:檢查一個string是否包含指定的Unicode字元。

語法如下:

// 檢查一個string是否包含另一個string。
func strings.Contains(s, substr string) bool

// 檢查一個string是否包含任何指定的Unicode字元。
func strings.ContainsAny(s, chars string) bool

// 計算subString在目標string中出現的次數。
func strings.Count(s, substr string) int

// 檢查一個string是否包含指定的Unicode字元。
func strings.ContainsRune(s string, r rune) bool
package main

import (
"fmt"
"strings"
)

func main() {
text := "Hello, world! Hello, universe!"

// 檢查string是否包含另一個string
containsHello := strings.Contains(text, "Hello")
fmt.Println("Contains 'Hello':", containsHello) // true

// 檢查string是否包含指定的Unicode字元
containsAny := strings.ContainsAny(text, "aeiou")
fmt.Println("Contains any vowel:", containsAny) // true

// 計算subString在目標string中出現的次數
countHello := strings.Count(text, "Hello")
fmt.Println("Count 'Hello':", countHello) // 2

// 檢查string是否包含指定的Unicode字元
containsRune := strings.ContainsRune(text, 'H')
fmt.Println("Contains 'H':", containsRune) // true
}

修改功能

  • strings.Join:將多個string連接成一個新的string,並使用指定的分隔符分隔它們。
  • strings.Repeat:將一個string重複多次。
  • strings.Replace:替換string中的特定subString。
  • strings.ReplaceAll:替換string中的所有匹配subString。
  • strings.ToLower:將string轉換為小寫。
  • strings.ToUpper:將string轉換為大寫。
  • strings.Title:將string中的每個單字的首字母轉換為大寫。
  • strings.Trim:刪除string開頭和結尾的指定字符集合。
  • strings.TrimSpace:刪除string開頭和結尾的空格字符。
  • strings.TrimPrefix:刪除string開頭的指定前綴。
  • strings.TrimSuffix:刪除string結尾的指定後綴。
  • strings.TrimLeft:刪除string開頭的指定字符集合。
  • strings.TrimRight:刪除string結尾的指定字符集合。
  • strings.TrimFunc:使用自定義函數刪除string開頭和結尾的字符。

語法如下:

// 將多個string連接成一個新的string,並使用指定的分隔符分隔它們。
func strings.Join(strs []string, sep string) string

// 將一個string重複多次。
func strings.Repeat(s string, count int) string

// 替換string中的特定subString。
func strings.Replace(s, old, new string, n int) string

// 替換string中的所有匹配subString。
func strings.ReplaceAll(s, old, new string) string

// 將string轉換為小寫。
func strings.ToLower(s string) string

// 將string轉換為大寫。
func strings.ToUpper(s string) string

// 將string中的每個單字的首字母轉換為大寫。
func strings.Title(s string) string

// 刪除string開頭和結尾的指定字符集合。
func strings.Trim(s string, cutset string) string

// 刪除string開頭和結尾的空格字符。
func strings.TrimSpace(s string) string

// 刪除string開頭的指定前綴。
func strings.TrimPrefix(s, prefix string) string

// 刪除string結尾的指定後綴。
func strings.TrimSuffix(s, suffix string) string

// 刪除string開頭的指定字符集合。
func strings.TrimLeft(s string, cutset string) string

// 刪除string結尾的指定字符集合。
func strings.TrimRight(s string, cutset string) string

// 使用自定義函數刪除string開頭和結尾的字符。
func strings.TrimFunc(s string, f func(rune) bool) string
package main

import (
"fmt"
"strings"
)
func main() {
// string連接
words := []string{"apple", "banana", "cherry"}
joined := strings.Join(words, ", ")
fmt.Println(joined) // "apple, banana, cherry"

// string重複
text := "Go"
repeated := strings.Repeat(text, 3)
fmt.Println(repeated) // "GoGoGo"

// string替換
text = "Hello, world! Hello, universe!"

// 替換第一個匹配
replaced := strings.Replace(text, "Hello", "Hi", 1)
fmt.Println(replaced) // "Hi, world! Hello, universe!"

// 替換所有匹配
replacedAll := strings.ReplaceAll(text, "Hello", "Hi")
fmt.Println(replacedAll) // "Hi, world! Hi, universe!"

// string大小寫轉換
text = "Hello, World!"
lowerCase := strings.ToLower(text)
upperCase := strings.ToUpper(text)
fmt.Println(lowerCase) // "hello, world!"
fmt.Println(upperCase) // "HELLO, WORLD!"

// string前綴和後綴刪除
text = " Go is awesome! "

// 刪除string開頭和結尾的空格
trimmedText := strings.Trim(text, " ")
fmt.Printf("[%s]\n", trimmedText) // "[Go is awesome!]"

// 刪除string開頭的空格
trimmedLeftText := strings.TrimLeft(text, " ")
fmt.Printf("[%s]\n", trimmedLeftText) // "[Go is awesome! ]"

// 刪除string結尾的空格
trimmedRightText := strings.TrimRight(text, " ")
fmt.Printf("[%s]\n", trimmedRightText) // "[ Go is awesome!]"

// string前綴和後綴替換
prefixedText := "prefix: Hello, World!"
trimmedPrefixText := strings.TrimPrefix(prefixedText, "prefix: ")
fmt.Println(trimmedPrefixText) // "Hello, World!"

suffixedText := "Hello, World! -suffix"
trimmedSuffixText := strings.TrimSuffix(suffixedText, " -suffix")
fmt.Println(trimmedSuffixText) // "Hello, World!"

// 使用自定義函數刪除string
trimFuncText := "###TrimMe###"
trimmedFuncText := strings.TrimFunc(trimFuncText, func(r rune) bool {
return r == '#'
})
fmt.Println(trimmedFuncText) // "TrimMe"
}

比較功能

  • strings.Compare:比較兩個string是否相等,不過直接使用==或是!=更直覺。

語法如下:

// 比較兩個string,返回比較結果的整數值。
func strings.Compare(a, b string) int
package main

import (
"fmt"
"strings"
)

func main() {
str1 := "apple"
str2 := "banana"

// 使用 strings.Compare 比較string
result := strings.Compare(str1, str2)

switch {
case result < 0:
fmt.Printf("%s 小於 %s\n", str1, str2)
case result > 0:
fmt.Printf("%s 大於 %s\n", str1, str2)
default:
fmt.Printf("%s 等於 %s\n", str1, str2)
}
}

切割功能

  • strings.Split:將string按照指定的分隔符分割成subString。
  • strings.SplitAfter:在指定的分隔符之後切割string。

語法如下:

// 將string按照指定的分隔符分割成subString。
func strings.Split(s, sep string) []string

// 在指定的分隔符之後切割string。
func strings.SplitAfter(s, sep string) []string
package main

import (
"fmt"
"strings"
)

func main() {
// 使用 strings.Split 函數按照逗號分割string
s1 := "apple,banana,cherry"
words1 := strings.Split(s1, ",")
fmt.Printf("使用 Split 函數分割的結果:%v\n", words1)

// 使用 strings.SplitAfter 函數在逗號之後分割string
s2 := "apple,banana,cherry"
words2 := strings.SplitAfter(s2, ",")
fmt.Printf("使用 SplitAfter 函數分割的結果:%v\n", words2)
}

其他功能

  • strings.Index:找到一個subString在目標string中的第一次出現的索引位置。
  • strings.LastIndex:找到一個subString在目標string中的最後一次出現的索引位置。
  • strings.Fields:將string拆分為slice的subString,使用空格作為分隔符。

語法如下:

// 找到一個subString在目標string中的第一次出現的索引位置。
func strings.Index(s, substr string) int

// 找到一個subString在目標string中的最後一次出現的索引位置。
func strings.LastIndex(s, substr string) int

// 將string拆分為slice的subString,使用空格作為分隔符。
func strings.Fields(s string) []string
package main

import (
"fmt"
"strings"
)

func main() {
s := "Hello, world! Welcome to the world of Go. Hello, Go world."

// 找到一個subString在目標string中的第一次出現的索引位置。
substr := "world"
index := strings.Index(s, substr)
if index != -1 {
fmt.Printf("'%s' 第一次出現的索引位置:%d\n", substr, index)
} else {
fmt.Printf("'%s' 未在string中找到\n", substr)
}

// 找到一個subString在目標string中的最後一次出現的索引位置。
lastIndex := strings.LastIndex(s, substr)
if lastIndex != -1 {
fmt.Printf("'%s' 最後一次出現的索引位置:%d\n", substr, lastIndex)
} else {
fmt.Printf("'%s' 未在string中找到\n", substr)
}

// 將string拆分為slice的subString,使用空格作為分隔符。
text := "This is a sample sentence."
fields := strings.Fields(text)
fmt.Println("拆分後的subString slice:")
for _, field := range fields {
fmt.Println(field)
}
}

📚Reference

avatar-img
17會員
83內容數
golang
留言0
查看全部
avatar-img
發表第一個留言支持創作者!
Alan的開發者天地 的其他內容
👨‍💻 簡介 昨天講到 os package,今天繼續補充 os package底下的 exec package,這個package主要用來執行外部指令和處理指令的輸入和輸出,包括如何設定指令、執行指令以及處理輸出等等。
👨‍💻 簡介 今天快速介紹一下對檔案的操作所使用的package os,包括檔案和資料夾操作等。 檔案和資料夾操作 os package 可以執行各種檔案和資料夾操作,如建立、讀取、寫入、刪除檔案,以及取得資料夾內容等。
👨‍💻簡介 在 Go 語言中,reflect package是用來檢查和操作變數的type、value和struct。常見用法有檢察 type、調用方法,以及修改變數的value。今天簡單介紹 reflect package的主要功能、使用方法和常見用法。
👨‍💻 簡介 今天的encoding/json package是我日常在開發web時很常用到的package之一,主要是用來將Go struct和 JSON 之間進行轉換。主要功能為資料序列化(marshalling)和反序列化(unmarshalling)。
👨‍💻簡介 要處理日期和時間,就必須知道這個Package -> time,Go提供了內建的timePackage。 今天主要介紹time的功能,包括時間操作、格式化等等,以及常見用法。
👨‍💻簡介 要印出Hello World,就會碰到這個Package -> fmt,今天來簡單整理一下fmt的作用、格式化的控制與常見用法。
👨‍💻 簡介 昨天講到 os package,今天繼續補充 os package底下的 exec package,這個package主要用來執行外部指令和處理指令的輸入和輸出,包括如何設定指令、執行指令以及處理輸出等等。
👨‍💻 簡介 今天快速介紹一下對檔案的操作所使用的package os,包括檔案和資料夾操作等。 檔案和資料夾操作 os package 可以執行各種檔案和資料夾操作,如建立、讀取、寫入、刪除檔案,以及取得資料夾內容等。
👨‍💻簡介 在 Go 語言中,reflect package是用來檢查和操作變數的type、value和struct。常見用法有檢察 type、調用方法,以及修改變數的value。今天簡單介紹 reflect package的主要功能、使用方法和常見用法。
👨‍💻 簡介 今天的encoding/json package是我日常在開發web時很常用到的package之一,主要是用來將Go struct和 JSON 之間進行轉換。主要功能為資料序列化(marshalling)和反序列化(unmarshalling)。
👨‍💻簡介 要處理日期和時間,就必須知道這個Package -> time,Go提供了內建的timePackage。 今天主要介紹time的功能,包括時間操作、格式化等等,以及常見用法。
👨‍💻簡介 要印出Hello World,就會碰到這個Package -> fmt,今天來簡單整理一下fmt的作用、格式化的控制與常見用法。
你可能也想看
Google News 追蹤
Thumbnail
給定一個字串陣列,請把它們所共有的字元伴隨著出現次數輸出。這篇文章介紹如何使用字典統計出現次數,和字典取交集的方法來解決此問題。並提供了複雜度分析和關鍵知識點。
Thumbnail
1.0 從函數到函算語法 1.1 句子成份 本書關注的是句子成份的分析。 如前述,詞類和句子成份是兩個很不一樣的概念。 詞類的劃分屬歸類性的描述。我們先有一個給定的詞彙,然後劃分若干詞類,比如名詞﹑動詞﹑形容詞等,再進而對詞彙中的每一個詞進行分類,即說某詞屬名詞﹑某詞屬動詞﹑某詞可以是名
Thumbnail
內容涵蓋資料型別、型別轉換、自訂型別、元組型別、集合型別和字典型別等主題。文章首先詳述內建型別如bool、byte、char等的定義和使用,接著討論型別轉換,包括隱含轉換和明確轉換。之後文章介紹自訂型別的建立,以及元組、集合、陣列和字典型別的操作與例子。
Thumbnail
接著介紹可以尋找文字的函式:FIND 跟 SEARCH。這兩個函式都會回傳指定文字第一次出現的位置,而這位置會以數字表示。
Thumbnail
接下來喜特先生會介紹一系列關於文字處理時,會常常運用到的函式。我們這次先從比較簡單的 LEN、CHAR 和 REPT 開始,之後會陸續介紹其他的。如果你有什麼想要了解的函式,歡迎在下面留言告訴我! LEN:字元長度 我們可以用 LEN 函式取得儲存格或字元的長度。 語法相當簡單:
Thumbnail
當我們在做很多處理時,結果可能會是List包住一些數值,例如找輪廓或連通域分析時,沒有剛好的特徵可能就會有List含(空值得)形式出現。 為了避免報錯,我們就要額外先做一些處理,先做判斷是否有值在往下一個階段。 all 和 any 是 Python 中用於檢查可迭代物件(如清單、元組、集合等)
※ 常用arry型態的方法: 長度: length 查詢第N個元素: [] 查詢元素在第N個: indexOf( ) 判斷是否為array: isArray() 新增和刪除: push():新增後面的數值 unshift():新增前面的數值 pop():刪除後面的數值 sh
Thumbnail
題目敘述 題目會給我們兩個輸入,字串s和字串t,要求我們判定s是否為t的子序列(Subsequence)? 題目的原文敘述 測試範例 Example 1: Input: s = "abc", t = "ahbgdc" Output: true Example 2: Input:
Thumbnail
題目敘述 題目會給定一個整數陣列arr,要求我們判斷是否每個元素的出現次數都不同? 題目的原文敘述 測試範例 Example 1: Input: arr = [1,2,2,1,1,3] Output: true Explanation: The value 1 has 3 occurre
Thumbnail
題目敘述 題目會給定我們兩個字串word1 和 word2。 允許我們不限制次數進行下列兩種操作: 任意調換其中兩個字元的位置。 把字串中的某個字元全部置換成另一個字元,同時把另一個字元同時置換成某個字元。(例如把字串中原本的a都換成b,把原本的b都換成a) 問我們能不能通過上述兩項操作,
Thumbnail
給定一個字串陣列,請把它們所共有的字元伴隨著出現次數輸出。這篇文章介紹如何使用字典統計出現次數,和字典取交集的方法來解決此問題。並提供了複雜度分析和關鍵知識點。
Thumbnail
1.0 從函數到函算語法 1.1 句子成份 本書關注的是句子成份的分析。 如前述,詞類和句子成份是兩個很不一樣的概念。 詞類的劃分屬歸類性的描述。我們先有一個給定的詞彙,然後劃分若干詞類,比如名詞﹑動詞﹑形容詞等,再進而對詞彙中的每一個詞進行分類,即說某詞屬名詞﹑某詞屬動詞﹑某詞可以是名
Thumbnail
內容涵蓋資料型別、型別轉換、自訂型別、元組型別、集合型別和字典型別等主題。文章首先詳述內建型別如bool、byte、char等的定義和使用,接著討論型別轉換,包括隱含轉換和明確轉換。之後文章介紹自訂型別的建立,以及元組、集合、陣列和字典型別的操作與例子。
Thumbnail
接著介紹可以尋找文字的函式:FIND 跟 SEARCH。這兩個函式都會回傳指定文字第一次出現的位置,而這位置會以數字表示。
Thumbnail
接下來喜特先生會介紹一系列關於文字處理時,會常常運用到的函式。我們這次先從比較簡單的 LEN、CHAR 和 REPT 開始,之後會陸續介紹其他的。如果你有什麼想要了解的函式,歡迎在下面留言告訴我! LEN:字元長度 我們可以用 LEN 函式取得儲存格或字元的長度。 語法相當簡單:
Thumbnail
當我們在做很多處理時,結果可能會是List包住一些數值,例如找輪廓或連通域分析時,沒有剛好的特徵可能就會有List含(空值得)形式出現。 為了避免報錯,我們就要額外先做一些處理,先做判斷是否有值在往下一個階段。 all 和 any 是 Python 中用於檢查可迭代物件(如清單、元組、集合等)
※ 常用arry型態的方法: 長度: length 查詢第N個元素: [] 查詢元素在第N個: indexOf( ) 判斷是否為array: isArray() 新增和刪除: push():新增後面的數值 unshift():新增前面的數值 pop():刪除後面的數值 sh
Thumbnail
題目敘述 題目會給我們兩個輸入,字串s和字串t,要求我們判定s是否為t的子序列(Subsequence)? 題目的原文敘述 測試範例 Example 1: Input: s = "abc", t = "ahbgdc" Output: true Example 2: Input:
Thumbnail
題目敘述 題目會給定一個整數陣列arr,要求我們判斷是否每個元素的出現次數都不同? 題目的原文敘述 測試範例 Example 1: Input: arr = [1,2,2,1,1,3] Output: true Explanation: The value 1 has 3 occurre
Thumbnail
題目敘述 題目會給定我們兩個字串word1 和 word2。 允許我們不限制次數進行下列兩種操作: 任意調換其中兩個字元的位置。 把字串中的某個字元全部置換成另一個字元,同時把另一個字元同時置換成某個字元。(例如把字串中原本的a都換成b,把原本的b都換成a) 問我們能不能通過上述兩項操作,