目录
重要性
字符串处理基本功,无论面试算法还是工作都经常使用到。以下我们以一个算法+一个实际工作场景的形式来阐述字符串处理。
以下算法都来自leecode中国
反转字符串
344
原题目要求不允许额外空间原地反转。
输入:s = ["h","e","l","l","o"]
输出:["o","l","l","e","h"]
直接一个循环反转了。
func reverseString(s []byte) { //双指针,一个放头一个放尾 i:=0 j:=len(s)-1 //反转这两个位置的元素 for i<j { s[i],s[j]=s[j],s[i] i++ j-- } }
pythonrevertGo
拆分与合并字符串
byte
s := []byte(str) reverseString(s) fmt.Println(string(s))
这样会把字符串变成一个个字节,想象一个场景你的文章有多个标签,全部塞到一个字段里。要拆分显示怎么操作?
# 拆分 strList := strings.Split("Go语言,channel,并发", ",") fmt.Println(strList) # 合并 str := strings.Join(strList,",") fmt.Println(str)
stringsstrings.Splitstrings.Join
忽略大小写判等
2s5G2s5g
全部转大写,或者全部转小写判等就行。我写粗糙一点,看不懂留言啊。
strings.ToLower("2s5G") == "2s5g" strings.ToUpper("2s5G") == "2S5G"
strings
fmt.Println(strings.EqualFold("abc", "ABC"))
蛇行命名转驼峰命名方式
涉及知识点:拆分、大小写转换、组合
func main() { name := "ab_cde_as" strList := strings.Split(name,"_") for index,str := range strList{ strList[index] = strings.ToUpper(string(str[0])) + str[1:] } name = strings.Join(strList,"") fmt.Println(name) }
AbCdeAsstr[0]str[1:][1,len(str)]
strings.Title("hello")Hello
替换和查找
sed
strings.Replace("ip:10.1.1.1", "10.1.1.1", "0.0.0.0", -1)
-11
当前正常情况下不会那么蠢啦,都是用正则匹配的,比如我之前有个需求把所有的图片网址取出来,存到我的对象存储里面,再插入回去,我就写了一个程序。
ok
regexStr := "https*://[^\\s]*(jpg|png)" if ok, _ := regexp.MatchString(regexStr, "https://coding3min.com/abc.jpg"); ok { fmt.Println("ok") }
开始搞
data := ` ![](http://coding3min.com/abc.jpg) [](https://coding3min.com/abc.html) ![](https://coding3min.com/abc.png) https://coding3min.com ` re, _ := regexp.Compile(regexStr) picList := re.FindAllString(data,-1) sort.Strings(picList) for k,v:=range picList{ if k!=0 && picList[k]==picList[k-1]{ continue } //省略改变图片链接 afterStr := "xxx" re,_ = regexp.Compile(v) data = re.ReplaceAllString(data,afterStr) } fmt.Println(data)
regexp.Compile(regexStr)re.FindAllString(data,-1)-1listre.ReplaceAllString(data,afterStr)
其他速查
10-1
strings.Compare("a", "b")
子串包含
fmt.Println(strings.Contains("hello", "he"))
返回子串出现的次数
fmt.Println(strings.Count("happy", "p"))
判断字符串是否以某子串开头、结尾
fmt.Println(strings.HasPrefix("hello", "he")) fmt.Println(strings.HasSuffix("hello", "lo"))
返回字符串第一次出现的位置 不存在返回-1
fmt.Println(strings.Index("abandon already", "a"))
返回字符串最后一次出现的位置 不存在返回-1
fmt.Println(strings.LastIndex("abandon already", "a"))
其他
utf8
您可能感兴趣的文章: