[TOC]
# 字符串處理
下面這些函數來自于string包
常用操作

## Fields以連續的空白字符為分隔符
~~~
// Fields 以連續的空白字符為分隔符,將 s 切分成多個子串,結果中不包含空白字符本身
// 空白字符有:\t, \n, \v, \f, \r, ' ', U+0085 (NEL), U+00A0 (NBSP)
// 如果 s 中只包含空白字符,則返回一個空列表
func Fields(s string) []string
~~~
~~~
func main() {
s := "Hello, 世界! Hello!"
ss := strings.Fields(s)
fmt.Printf("%q\n", ss) // ["Hello," "世界!" "Hello!"]
}
~~~
## contains包含子串
~~~
func Contains(s, substr string) bool
功能: 字符串s中是否包含substr,返回bool值
~~~
例子
~~~
func main() {
fmt.Println(strings.Contains("abc", "a")) //true
fmt.Println(strings.Contains("abc", "")) //true
fmt.Println(strings.Contains("", "")) //true
}
~~~
## join按指定方式拼接
~~~
func Join(a []string, seq string) string
功能: 字符串鏈接,把slice a通過sep鏈接起來
~~~
例子
~~~
func main() {
s := []string{"foo", "bar", "baz"}
//foo, bar, baz
fmt.Println(strings.Join(s, ", "))
}
~~~
## index找位置
還有個LastIndex表示最后出現的位置
~~~
func Index(s, sep string) int
功能: 在字符串s中查找sep所在的位置,返回位置值,找不到返回-1
~~~
例子
~~~
func main() {
//3
fmt.Println(strings.Index("chiken", "ken"))
}
~~~
## repeat重復多少次
~~~
func Repeat(s string, count int) string
功能: 重復s字符串count次,最后返回重復的字符串
~~~
例子
~~~
func main() {
//banana
fmt.Println("ba" + strings.Repeat("na", 2))
}
~~~
## replace按指定替換
~~~
fiunc Replace(s, old, new string, n int) string
功能: 在s字符串中,把old字符串替換為new字符串,n表示替換的次數,小于0表示全部替換
~~~
例子
~~~
func main() {
//ab1 efg 1cc
fmt.Println(strings.Replace("abc efg ccc", "c", "1", 2))
}
~~~
## split分割
~~~
func Split(s, sep string) []string
功能: 把s字符串按照sep分割,返回slice
~~~
例子
~~~
func main() {
//["a" "b" "c"]
fmt.Printf("%q\n", strings.Split("a,b,c", ","))
//["" " is c"]
fmt.Printf("%q\n", strings.Split("a is c", "a"))
}
~~~
## Trim頭尾去除指定的串
~~~
func Trim(s string, cutset string) string
功能: 在s字符串的頭部和尾部去除cutset指定的字符串
~~~
例子
~~~
func main() {
//["aaa"]
fmt.Printf("[%q]", strings.Trim(" !!!aaa!!! ", " !"))
}
~~~
# 字符串轉換
## Append
將整數等轉換為字符串后,添加到現有的字節數組中
~~~
func main() {
//字節數組
str := make([]byte, 0, 100)
str = strconv.AppendBool(str, false)
//以10進制的方式追加,參數10
str = strconv.AppendInt(str, 111, 10)
str = strconv.AppendQuote(str, "abcde")
str = strconv.AppendQuoteRune(str, '單')
//false111"abcde"'單'
//轉為string打印
fmt.Println(string(str))
}
~~~
## Format
Format系列函數把其他類型的轉換為字符串
例子
~~~
a := strconv.FormatBool(false)
//10進制
b := strconv.FormatInt(1234, 10)
c := strconv.FormatUint(123444, 10)
//整形轉字符串
d := strconv.Itoa(1234)
//false 1234 123444 1234
fmt.Println(a, b, c, d)
~~~
## parse
parse系列函數把字符串轉換為其他類型
~~~
//字符串轉其他類型
var flag bool
var err error
flag, err = strconv.ParseBool("true")
if err == nil {
//沒有錯誤
fmt.Println("flag = ", flag)
} else {
fmt.Println("err = ", err)
}
~~~
## Atoi
~~~
func main() {
//_表示丟棄
a, _ := strconv.Atoi("567")
fmt.Println(a)
}
~~~
# 和切片轉換
長度是字節的長度
字符串底層是一個byte數組,所以可以和`[]byte`類型互相轉換
字符串是不可以修改的
~~~
var str = "hello你好"
fmt.Printf("str[0]=%c, len(str)=%d\n", str[0], len(str))
for index, val := range str {
fmt.Println(index, val)
}
//str['0'] = '1' 錯誤不能修改
var byteSlice []byte
byteSlice = []byte(str)
byteSlice[0] = '0'
str = string(byteSlice)
fmt.Println(str)
~~~
輸出
~~~
str[0]=h, len(str)=11
0 104
1 101
2 108
3 108
4 111
5 20320
8 22909
0ello你好
~~~
# 字節長度和字符長度
rune是字符類型
~~~
var str = "hello你好"
//字節數組
var rune []byte
rune = []byte(str)
//11, 11
fmt.Println(len(str), len(rune))
var str = "hello你好"
//rune是字符類型
var byteSlice []rune
byteSlice = []rune(str)
//11, 7
fmt.Println(len(str), len(byteSlice))
~~~
# string和int互相轉換
* string轉成int:
~~~
int, err := strconv.Atoi(string)
~~~
* string轉成int64:
~~~
int64, err := strconv.ParseInt(string, 10, 64)
~~~
* int轉成string:
~~~
string := strconv.Itoa(int)
~~~
* int64轉成string:
~~~
string := strconv.FormatInt(int64,10)
~~~
* string 轉 int32
~~~
i32,err := strconv.ParseInt(str,10,32)
if err == nil {
fmt.Printf("i32: %v\\n", int32(i32))
}
~~~
* int到int64
~~~
int64_ := int64(1234)
~~~
# string和float float32 float64
* float到string
~~~
string := strconv.FormatFloat(float32,'E',-1,32)
string := strconv.FormatFloat(float64,'E',-1,64)
// 'b' (-ddddp±ddd,二進制指數)
// 'e' (-d.dddde±dd,十進制指數)
// 'E' (-d.ddddE±dd,十進制指數)
// 'f' (-ddd.dddd,沒有指數)
// 'g' ('e':大指數,'f':其它情況)
// 'G' ('E':大指數,'f':其它情況)
~~~
* string到float64
~~~
float,err := strconv.ParseFloat(string,64)
~~~
* string到float32
~~~
float,err := strconv.ParseFloat(string,32)
~~~
# string到time
~~~
day,_ := time.Parse("2006-01-02", "2017-11-14")
month := time.Unix(day.Unix(), 0).Format("2006-01") //返回2017-11
~~~
- 基礎
- 簡介
- 主要特征
- 變量和常量
- 編碼轉換
- 數組
- byte與rune
- big
- sort接口
- 和mysql類型對應
- 函數
- 閉包
- 工作區
- 復合類型
- 指針
- 切片
- map
- 結構體
- sync.Map
- 隨機數
- 面向對象
- 匿名組合
- 方法
- 接口
- 權限
- 類型查詢
- 異常處理
- error
- panic
- recover
- 自定義錯誤
- 字符串處理
- 正則表達式
- json
- 文件操作
- os
- 文件讀寫
- 目錄
- bufio
- ioutil
- gob
- 棧幀的內存布局
- shell
- 時間處理
- time詳情
- time使用
- new和make的區別
- container
- list
- heap
- ring
- 測試
- 單元測試
- Mock依賴
- delve
- 命令
- TestMain
- path和filepath包
- log日志
- 反射
- 詳解
- plugin包
- 信號
- goto
- 協程
- 簡介
- 創建
- 協程退出
- runtime
- channel
- select
- 死鎖
- 互斥鎖
- 讀寫鎖
- 條件變量
- 嵌套
- 計算單個協程占用內存
- 執行規則
- 原子操作
- WaitGroup
- 定時器
- 對象池
- sync.once
- 網絡編程
- 分層模型
- socket
- tcp
- udp
- 服務端
- 客戶端
- 并發服務器
- Http
- 簡介
- http服務器
- http客戶端
- 爬蟲
- 平滑重啟
- context
- httptest
- 優雅中止
- web服務平滑重啟
- beego
- 安裝
- 路由器
- orm
- 單表增刪改查
- 多級表
- orm使用
- 高級查詢
- 關系查詢
- SQL查詢
- 元數據二次定義
- 控制器
- 參數解析
- 過濾器
- 數據輸出
- 表單數據驗證
- 錯誤處理
- 日志
- 模塊
- cache
- task
- 調試模塊
- config
- 部署
- 一些包
- gjson
- goredis
- collection
- sjson
- redigo
- aliyunoss
- 密碼
- 對稱加密
- 非對稱加密
- 單向散列函數
- 消息認證
- 數字簽名
- mysql優化
- 常見錯誤
- go run的錯誤
- 新手常見錯誤
- 中級錯誤
- 高級錯誤
- 常用工具
- 協程-泄露
- go env
- gometalinter代碼檢查
- go build
- go clean
- go test
- 包管理器
- go mod
- gopm
- go fmt
- pprof
- 提高編譯
- go get
- 代理
- 其他的知識
- go內存對齊
- 細節總結
- nginx路由匹配
- 一些博客
- redis為什么快
- cpu高速緩存
- 常用命令
- Go 永久阻塞的方法
- 常用技巧
- 密碼加密解密
- for 循環迭代變量
- 備注
- 垃圾回收
- 協程和纖程
- tar-gz
- 紅包算法
- 解決golang.org/x 下載失敗
- 逃逸分析
- docker
- 鏡像
- 容器
- 數據卷
- 網絡管理
- 網絡模式
- dockerfile
- docker-composer
- 微服務
- protoBuf
- GRPC
- tls
- consul
- micro
- crontab
- shell調用
- gorhill/cronexpr
- raft
- go操作etcd
- mongodb