Golang 統(tǒng)計字符串字數(shù)的方法示例
比如新浪微博發(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 main
import (
"fmt"
)
func main() {
var str string = "abc鄭闖" //共9個字節(jié)
charray := []byte(str) //轉換為byte:一個字節(jié)對應一個數(shù)組元素
fmt.Println(len(charray)) //獲取元素的個數(shù),結果為9
for _, v := range charray {
fmt.Printf("%c", v) //輸出結果為:abcéé¯
}
}
輸出:
9
abcéé¯
2:獲取字符串元素的個數(shù),并按元素挨個輸出
package main
import (
"fmt"
)
func main() {
a := "I love my family!我愛我的家人!"
b := []rune(a) //轉換為rune:一個字符對應一個元素 (共24個)
fmt.Println(len(b)) //獲取元素的個數(shù)(24)
for _, v2 := range b {
fmt.Printf("%c", v2) //輸出結果:I love my family!我愛我的家人!
}
}
輸出:
24
I love my family!我愛我的家人!
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
go實現(xiàn)grpc四種數(shù)據(jù)流模式
這篇文章主要為大家介紹了go實現(xiàn)grpc四種數(shù)據(jù)流模式,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步早日升職加薪2022-04-04

