image.png
如圖代碼所示:
截取思路一: 把字符串轉成字節(jié)數(shù)組,然后使用slice切片得到其中想要截取的一段
image.png
但是因為處理的字符串中可能還存在中文,而中文一般不止占一個字節(jié),在go語言中一個中文一般占用3個字節(jié),那么如果按照字節(jié)數(shù)組處理的話,還需要遍歷每個字節(jié),判斷編碼,判斷ascii碼,處理起來也就復雜了.
截圖思路二:如果中文也只占用一個數(shù)組下標就好了,查看文檔發(fā)現(xiàn)rune類型滿足需求.
Go語言的字符有以下兩種:
- 一種是 uint8 類型,或者叫 byte 型,代表了 ASCII 碼的一個字符。
- 另一種是 rune 類型,代表一個 UTF-8 字符,當需要處理中文、日文或者其他復合字符時,則需要用到 rune 類型。rune 類型等價于 int32 類型。
因此這里我采用了rune類型,首先將參數(shù)str轉為rune類型,再獲取需要的片段,再轉換為string類型,得到了需要替換的部分,再使用strings包中的替換函數(shù)ReplaceAll進行處理得到我們所需要的字符串.
另外記錄下,string函數(shù)不能直接轉換interface{}類型,不過可以使用如下語法:
image.png
name, ok := x.(T) 類型斷言語法,檢查x是否為T類型,是的話返回值給name.返回bool值給ok,當x為nil時或者未接收ok返回值時,斷言失敗都會直接panic
go語言中判斷null值,使用的是nil
item["name"] = null
image.png