比如新浪微博發微博的輸入框有一個已輸入字數的統計,它的規則推測是:漢字和中文標點算 1 個字數,英文和其他符號算 0.5 個字數。不足 1 個字算 1 個。大家可以去微博體驗一下計算方式。
golang 可以使用正則和 unicode 包的方法判斷。
以下函數 GetStrLength 返回輸入的字符串的字數,每個漢字和中文標點算 1 個字數,英文和其他字符算半個字數,不足 1 個字算 1 個。
1
2
3
4
5
6
7
8
9
10
11
12
13
|
// GetStrLength 返回輸入的字符串的字數,漢字和中文標點算 1 個字數,英文和其他字符 2 個算 1 個字數,不足 1 個算 1個 func GetStrLength(str string) float64 { var total float64 reg := regexp.MustCompile("/·|,|。|《|》|‘|'|”|“|;|:|【|】|?|(|)|、/") for _, r := range str { if unicode.Is(unicode.Scripts["Han"], r) || reg.Match([]byte(string(r))) { total = total + 1 } else { total = total + 0.5 } } return math.Ceil(total) } |
1:獲取字符串字節的個數,并按字節挨個輸出
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
package main import ( "fmt" ) func main() { var str string = "abc鄭闖" //共9個字節 charray := []byte(str) //轉換為byte:一個字節對應一個數組元素 fmt.Println(len(charray)) //獲取元素的個數,結果為9 for _, v := range charray { fmt.Printf("%c", v) //輸出結果為:abcéé¯ } } |
輸出:
9
abcéé¯
2:獲取字符串元素的個數,并按元素挨個輸出
1
2
3
4
5
6
7
8
9
10
11
12
13
|
package main import ( "fmt" ) func main() { a := "I love my family!我愛我的家人!" b := []rune(a) //轉換為rune:一個字符對應一個元素 (共24個) fmt.Println(len(b)) //獲取元素的個數(24) for _, v2 := range b { fmt.Printf("%c", v2) //輸出結果:I love my family!我愛我的家人! } } |
輸出:
24
I love my family!我愛我的家人!
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。
原文鏈接:https://blog.tanteng.me/2018/05/golang-str-length