Go語言學習筆記17.字符串和json處理

字符串處理

這裏只展示了常用的,更多的可以去看文檔。文檔地址在第一篇裏面有。

func Contains(s, substr string) bool
功能:字符串s中是否包含substr,返回bool值
fmt.Println(strings.Contains("seafood", "foo"))

func Join(a []string, sep string) string
功能:字符串鏈接,把slice a通過sep鏈接起來
s := []string{"foo", "bar", "baz"}
fmt.Println(strings.Join(s, ", "))
//運行結果:foo, bar, baz

func Split(s, sep string) []string
功能:把s字符串按照sep分割,返回slice
fmt.Printf("%q\n", strings.Split("a,b,c", ","))
//["a" "b" "c"]

func Index(s, sep string) int
功能:在字符串s中查找sep所在的位置,返回位置值,找不到返回-1
fmt.Println(strings.Index("chicken", "ken"))

func Repeat(s string, count int) string
功能:重複s字符串count次,最後返回拼接好的字符串
fmt.Println("ba" + strings.Repeat("na", 2))
//運行結果:banana

func Replace(s, old, new string, n int) string
功能:在s字符串中,把old字符串替換爲new字符串,n表示替換的次數,小於0表示全部替換
fmt.Println(strings.Replace("oink oink oink", "oink", "moo", -1))

func Trim(s string, cutset string) string
功能:在s字符串的頭部和尾部去除cutset指定的字符串
fmt.Printf("[%q]", strings.Trim(" !!! Achtung !!! ", "! "))
//運行結果:["Achtung"]

func Fields(s string) []string
功能:去除s字符串的空格符,並且按照空格分割返回slice
fmt.Printf("Fields are: %q", strings.Fields("  foo bar  baz   "))
//運行結果:Fields are: ["foo" "bar" "baz"]

字符串轉換

Append 系列函數將整數等轉換爲字符串後,添加到現有的字節數組中。
str := make([]byte, 0, 100)
str = strconv.AppendInt(str, 4567, 10) //以10進制方式追加
str = strconv.AppendBool(str, false)
str = strconv.AppendQuote(str, "abcdefg")
str = strconv.AppendQuoteRune(str, '單')
fmt.Println(string(str)) //4567false"abcdefg"'單'

Format 系列函數把其他類型的轉換爲字符串。
a := strconv.FormatBool(false)
b := strconv.FormatInt(1234, 10)
c := strconv.FormatUint(12345, 10)
d := strconv.Itoa(1023)
fmt.Println(a, b, c, d) //false 1234 12345 1023

Parse 系列函數把字符串轉換爲其他類型。
a, err := strconv.ParseBool("false")
b, err := strconv.ParseFloat("123.23", 64)
c, err := strconv.ParseInt("1234", 10, 64)
d, err := strconv.ParseUint("12345", 10, 64)
e, err := strconv.Atoi("1023")
fmt.Println(a, b, c, d, e) //false 123.23 1234 12345 1023

正則表達式

package main

import (
	"fmt"
	"regexp"
)

func main() {

	buf := "abc azc a7c aac 888 a9c  tac a9c"

	//1) 解釋規則, 它會解析正則表達式,如果成功返回解釋器
	reg2 := regexp.MustCompile(`a.c`)
	fmt.Println("reg2 = ",reg2) //reg2 =  a.c
	reg3 := regexp.MustCompile(`a[0-9]c`)
	fmt.Println("reg3 = ",reg3)//reg3 =  a[0-9]c

	reg1 := regexp.MustCompile(`a\dc`)
	if reg1 == nil { //解釋失敗,返回nil
		fmt.Println("regexp err")
		return
	}

	//2) 返回符合規則的[]string切片,如果沒有匹配到,會返回nil。
	result1 := reg1.FindAllStringSubmatch(buf, -1)
	fmt.Println("result1 = ", result1)//[[a7c] [a9c] [a9c]]

	result2 := reg1.FindAllString(buf, -1) 
	fmt.Println("result2 = ", result2)//[a7c a9c a9c]

}

在這裏插入圖片描述

json

package main

import (
	"encoding/json"
	"fmt"
)

//首字母是大寫纔會被輸出
type IT struct {
	Company  string   `json:"-"`        //此字段不會輸出到屏幕
	Subjects []string `json:"subjects"` //二次編碼
	IsOk     bool     `json:",string"`  //會轉換成string再輸出到json
	Price    float64  `json:",string"`
	Type     int      `json:",omitempty"`//爲空則不會輸出
}

func main() {
	
	s := IT{"itcast", []string{"Go", "C++", "Python", "Test"}, true, 666.666,0}

	//編碼,根據內容生成json文本
	buf, err := json.Marshal(s) //生成一段JSON格式的文本
	if err != nil {
		fmt.Println("err = ", err)
		return
	}
	fmt.Println("buf = ", string(buf)) 
	//buf =  {"subjects":["Go","C++","Python","Test"],"IsOk":"true","Price":"666.666"}   注意沒有type

	s2 := IT{"itcast", []string{"Go", "C++", "Python", "Test"}, true, 666.666,1}

	buf2, err := json.MarshalIndent(s2, "", "	") //格式化編碼
	if err != nil {
		fmt.Println("err = ", err)
		return
	}
	fmt.Println("buf = ", string(buf2))
	/**
	buf =  {
        "subjects": [
                "Go",
                "C++",
                "Python",
                "Test"
        ],
        "IsOk": "true",
        "Price": "666.666",
		"Type": 1
	}
	*/

}

map轉json:

func main() {
	//創建一個map
	m := make(map[string]interface{}, 4)
	m["company"] = "itcast"
	m["subjects"] = []string{"Go", "C++", "Python", "Test"}
	m["isok"] = true
	m["price"] = 666.666

	//編碼成json
	//result, err := json.Marshal(m)
	result, err := json.MarshalIndent(m, "", "	")
	if err != nil {
		fmt.Println("err = ", err)
		return
	}
	fmt.Println("result = ", string(result))
}

json轉結構體

package main

import (
	"encoding/json"
	"fmt"
)

type IT struct {
	Company  string   `json:"company"`
	Subjects []string `json:"subjects"` //二次編碼
	IsOk     bool     `json:"isok"`
	Price    float64  `json:"price"`
}

type IT2 struct {
	Subjects []string `json:"subjects"` //二次編碼
}

func main() {

	jsonBuf := `
			{
			"company": "itcast",
			"subjects": [
				"Go",
				"C++",
				"Python",
				"Test"
			],
			"isok": true,
			"price": 666.666
		}`

	var tmp IT                                   //定義一個結構體變量
	err := json.Unmarshal([]byte(jsonBuf), &tmp) //第二個參數要地址傳遞
	if err != nil {
		fmt.Println("err = ", err)
		return
	}
	fmt.Printf("tmp = %+v\n", tmp) //tmp = {Company:itcast Subjects:[Go C++ Python Test] IsOk:true Price:666.666}

	//只接受部分數據
	var tmp2 IT2
	err = json.Unmarshal([]byte(jsonBuf), &tmp2) //第二個參數要地址傳遞
	if err != nil {
		fmt.Println("err = ", err)
		return
	}
	fmt.Printf("tmp2 = %+v\n", tmp2)

}

json轉map

	m := make(map[string]interface{}, 4)

	err := json.Unmarshal([]byte(jsonBuf), &m) //第二個參數要地址傳遞
	if err != nil {
		fmt.Println("err = ", err)
		return
	}
	fmt.Printf("m = %+v\n", m) //m = map[company:itcast isok:true price:666.666 subjects:[Go C++ Python Test]]
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章