比如新浪微博發(fā)微博的輸入框有一個已輸入字數(shù)的統(tǒng)計,它的規(guī)則推測是:漢字和中文標點算 1 個字數(shù),英文和其他符號算 0.5 個字數(shù)。不足 1 個字算 1 個。大家可以去微博體驗一下計算方式。
golang 可以使用正則和 unicode 包的方法判斷。
以下函數(shù) GetStrLength 返回輸入的字符串的字數(shù),每個漢字和中文標點算 1 個字數(shù),英文和其他字符算半個字數(shù),不足 1 個字算 1 個。
// GetStrLength 返回輸入的字符串的字數(shù),漢字和中文標點算 1 個字數(shù),英文和其他字符 2 個算 1 個字數(shù),不足 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:獲取字符串字節(jié)的個數(shù),并按字節(jié)挨個輸出
package mainimport ( "fmt")func main() { var str string = "abc鄭闖" //共9個字節(jié) charray := []byte(str) //轉(zhuǎn)換為byte:一個字節(jié)對應(yīng)一個數(shù)組元素 fmt.Println(len(charray)) //獲取元素的個數(shù),結(jié)果為9 for _, v := range charray { fmt.Printf("%c", v) //輸出結(jié)果為:abcéé¯ }}
輸出:
9
abcéé¯
2:獲取字符串元素的個數(shù),并按元素挨個輸出
package mainimport ( "fmt")func main() { a := "I love my family!我愛我的家人!" b := []rune(a) //轉(zhuǎn)換為rune:一個字符對應(yīng)一個元素 (共24個) fmt.Println(len(b)) //獲取元素的個數(shù)(24) for _, v2 := range b { fmt.Printf("%c", v2) //輸出結(jié)果:I love my family!我愛我的家人! }}
輸出:
24
I love my family!我愛我的家人!
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網(wǎng)。
新聞熱點
疑難解答