昨天遇到一个问题,strings.TrimRight("cyeamblog.go", ".go")
结果居然是"cyeambl"
,这让我百思不得其解。当然,要看官方文档的解释:
func TrimRight(s string, cutset string) string TrimRight returns a slice of the string s, with all trailing Unicode code points contained in cutset removed.
func TrimSuffix(s, suffix string) string TrimSuffix returns s without the provided trailing suffix string. If s doesn’t end with suffix, s is returned unchanged.
TrimSuffix
能看明白,这也是我想要用的,符合我的要求。但是这个TrimRight
怎么看也不知道有啥区别。除了代码结果不一样以别的都不清楚了。今天去大Google上面去搜,看到这个标题Is this a bug? strings.TrimRight seems to be cutting too much,乐死我了。我也是这样想的呀,只不过不好意思上去问。
看了这个算是弄明白了。大概解释说明一下,TrimRight
会把第二个参数字符串里面所有的字符拿出来处理,只要与其中任何一个字符相等,将其删除。也就是cutset
参数所有字符排列组合的形式进行删除。
最否附上一个例子:
package main
import (
"log"
"strings"
)
func main() {
log.Println(strings.TrimRight("abba", "ba"))
log.Println(strings.TrimRight("abcdaaaaa", "abcd"))
log.Println(strings.TrimSuffix("abcddcba", "dcba"))
}
结果:
2015/08/13 15:56:30
2015/08/13 15:56:30
2015/08/13 15:56:30 abcd
本文所涉及到的完整源码请参考。
######参考文献 1. Is this a bug? strings.TrimRight seems to be cutting too much.. - golang-nuts
原文链接:Golang strings包的TrimRight和TrimSuffix的区别,转载请注明来源!
有疑问加站长微信联系(非本文作者)