golang strings包的Replace的使用說明
函數聲明:
func Trim(s string, cutset string) string
官方描述:
返回將 s 前後端所有 cutset 包含的 utf-8 碼值都去掉的字符串。
示例代碼:
package main import ( "fmt" "strings" _ "test/subpac" ) func main(){ fmt.Println("[ !!! Achtung! Achtung! !!! ]:[]:[", strings.Trim(" !!! Achtung! Achtung! !!! ", "") ,"\b]") fmt.Println("[ !!! Achtung! Achtung! !!! ]:[ ]:[", strings.Trim(" !!! Achtung! Achtung! !!! ", " ") ,"\b]") fmt.Println("[ !!! Achtung! Achtung! !!! ]:[!]:[", strings.Trim(" !!! Achtung! Achtung! !!! ", "!") , "\b]") fmt.Println("[ !!! Achtung! Achtung! !!! ]:[! ]:[", strings.Trim(" !!! Achtung! Achtung! !!! ", "! "), "\b]" ) }
輸出結果:
[ !!! Achtung! Achtung! !!! ]:[]:[ !!! Achtung! Achtung! !!! ] [ !!! Achtung! Achtung! !!! ]:[ ]:[ !!! Achtung! Achtung! !!!] [ !!! Achtung! Achtung! !!! ]:[!]:[ !!! Achtung! Achtung! !!! ] [ !!! Achtung! Achtung! !!! ]:[! ]:[ Achtung! Achtung]
第一行 cutset 為空(不是空格):因此輸出原字符串。
第二行 cutset 為 ” “(空格):因此串首尾的兩個空格字符被刪除瞭。
第三行 cutset 為 “!” :收尾未匹配到該 cutset,因此輸出原字符串。
第四行 cutset 為 “! “:首先匹配到空格,串首尾空格字符被刪除,然後匹配到 “!”,繼續刪除首尾的各三個 “!”,於是得到該結果串。
註:輸出結果多餘的空格是因為 Println 在輸出多個串時會在串之間添加空格。如下:
fmt.Println("123", "456", "789")
輸出:
123 456 789
補充:golang_strings:trim分割“/“出現的坑及解決辦法
問題描述
strings.Trim和strings.TrimLeft在分割帶有“https://”的字符串時,會多分割一些字符,對分割結果造成影響。
推測原因:
TrimLeft 隻針對utf-8字符進行處理,相關處理可能出現問題。// todo源碼沒看太懂,哪位大佬明白的可以幫忙解釋下
解決辦法
測試代碼如下:
package main import ( "fmt" "strings" ) // TrimLeft和Trim分割字符串時,對於有"/"的字符串切割會出現問題 // 切割前綴使用TrimPrefix,切割後綴使用TrimSuffix進行代替 func main() { Url := "https://www.baidu.com/material/list" fmt.Println(strings.TrimLeft(Url, "https://www.baidu.com")) // erial/list fmt.Println(strings.TrimPrefix(Url, "https://www.baidu.com")) // /material/list Url2 := ":www.baidu.com/material/list" fmt.Println(strings.Trim(Url, "https://www.baidu.com")) // erial/l fmt.Println(strings.Trim(Url2, ":www.baidu.com")) // /material/list s := "Goodbye,, world!" fmt.Println(strings.TrimSuffix(s, ", world!")) // Goodbye, }
以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。如有錯誤或未考慮完全的地方,望不吝賜教。