# Convertor convertor 转换器包支持一些常见的数据类型转换
## 源码: [https://github.com/duke-git/lancet/blob/v1/convertor/convertor.go](https://github.com/duke-git/lancet/blob/v1/convertor/convertor.go)
## 用法: ```go import ( "github.com/duke-git/lancet/convertor" ) ```
## 目录 - [ColorHexToRGB](#ColorHexToRGB) - [ColorRGBToHex](#ColorRGBToHex) - [ToBool](#ToBool) - [ToBytes](#ToBytes) - [ToChar](#ToChar) - [ToChannel](#ToChannel) - [ToFloat](#ToFloat) - [ToInt](#ToInt) - [ToJson](#ToJson) - [ToString](#ToString) - [StructToMap](#StructToMap) - [EncodeByte](#EncodeByte) - [DecodeByte](#DecodeByte) - [DeepClone](#DeepClone) - [CopyProperties](#CopyProperties) - [ToInterface](#ToInterface) - [Utf8ToGbk](#Utf8ToGbk) - [GbkToUtf8](#GbkToUtf8)
## 文档 ### ColorHexToRGB

颜色值十六进制转rgb

函数签名: ```go func ColorHexToRGB(colorHex string) (red, green, blue int) ``` 列子: ```go package main import ( "fmt" "github.com/duke-git/lancet/convertor" ) func main() { colorHex := "#003366" r, g, b := ColorHexToRGB(colorHex) fmt.Println(r, g, b) //0,51,102 } ``` ### ColorRGBToHex

颜色值rgb转十六进制

函数签名: ```go func ColorRGBToHex(red, green, blue int) string ``` 列子: ```go package main import ( "fmt" "github.com/duke-git/lancet/convertor" ) func main() { r := 0 g := 51 b := 102 colorHex := ColorRGBToHex(r, g, b) fmt.Println(colorHex) //#003366 } ``` ### ToBool

字符串转布尔类型,使用strconv.ParseBool

函数签名: ```go func ToBool(s string) (bool, error) ``` 列子: ```go package main import ( "fmt" "github.com/duke-git/lancet/convertor" ) func main() { v1, _ := convertor.ToBool("1") fmt.Println(v1) //true v2, _ := convertor.ToBool("true") fmt.Println(v2) //true v3, _ := convertor.ToBool("True") fmt.Println(v3) //true v4, _ := convertor.ToBool("123") fmt.Println(v4) //false } ``` ### ToBytes

interface转字节切片.

函数签名: ```go func ToBytes(data interface{}) ([]byte, error) ``` 列子: ```go package main import ( "fmt" "github.com/duke-git/lancet/convertor" ) func main() { bytesData, err := convertor.ToBytes("0") if err != nil { fmt.Println(err) } fmt.Println(bytesData) //[]bytes{3, 4, 0, 0} } ``` ### ToChar

字符串转字符切片

函数签名: ```go func ToChar(s string) []string ``` 列子: ```go package main import ( "fmt" "github.com/duke-git/lancet/convertor" ) func main() { chars := convertor.ToChar("") fmt.Println(chars) //[]string{""} chars = convertor.ToChar("abc") fmt.Println(chars) //[]string{"a", "b", "c"} chars = convertor.ToChar("1 2#3") fmt.Println(chars) //[]string{"1", " ", "2", "#", "3"} } ``` ### ToChannel

将切片转为只读channel

函数签名: ```go func ToChannel(array []interface{}) <-chan interface{} ``` 例子: ```go package main import ( "fmt" "github.com/duke-git/lancet/convertor" ) func main() { ch := convertor.ToChannel([]int{1, 2, 3}) val1, _ := <-ch fmt.Println(val1) //1 val2, _ := <-ch fmt.Println(val2) //2 val3, _ := <-ch fmt.Println(val3) //3 _, ok := <-ch fmt.Println(ok) //false } ``` ### ToFloat

将interface转成float64类型,如果参数无法转换,会返回0和error

函数签名: ```go func ToFloat(value interface{}) (float64, error) ``` 列子: ```go package main import ( "fmt" "github.com/duke-git/lancet/convertor" ) func main() { v, err := convertor.ToFloat("") if err != nil { fmt.Println(err) //strconv.ParseFloat: parsing "": invalid syntax } fmt.Println(v) //0 v, _ = convertor.ToFloat("-.11") fmt.Println(v) //-0.11 } ``` ### ToInt

将interface转成intt64类型,如果参数无法转换,会返回0和error

函数签名: ```go func ToInt(value interface{}) (int64, error) ``` 例子: ```go package main import ( "fmt" "github.com/duke-git/lancet/convertor" ) func main() { v, err := convertor.ToInt("") if err != nil { fmt.Println(err) //strconv.ParseInt: parsing "": invalid syntax } fmt.Println(v) //0 v, _ = convertor.ToFloat(1.12) fmt.Println(v) //1 } ``` ### ToJson

将interface转成json字符串,如果参数无法转换,会返回""和error

函数签名: ```go func ToJson(value interface{}) (string, error) ``` 列子: ```go package main import ( "fmt" "github.com/duke-git/lancet/convertor" ) func main() { var aMap = map[string]int{"a": 1, "b": 2, "c": 3} jsonStr, _ := convertor.ToJson(aMap) fmt.Printf("%q", jsonStr) //"{\"a\":1,\"b\":2,\"c\":3}" } ``` ### ToString

将interface转成字符串

函数签名: ```go func ToString(value interface{}) string ``` 例子: ```go package main import ( "fmt" "github.com/duke-git/lancet/convertor" ) func main() { fmt.Printf("%q", convertor.ToString(1)) //"1" fmt.Printf("%q", convertor.ToString(1.1)) //"1.1" fmt.Printf("%q", convertor.ToString([]int{1, 2, 3})) //"[1,2,3]" } ``` ### StructToMap

将struct转成map,只会转换struct中可导出的字段。struct中导出字段需要设置json tag标记

函数签名: ```go func StructToMap(value interface{}) (map[string]interface{}, error) ``` 列子: ```go package main import ( "fmt" "github.com/duke-git/lancet/convertor" ) func main() { type People struct { Name string `json:"name"` age int } p := People{ "test", 100, } pm, _ := convertor.StructToMap(p) fmt.Printf("type: %T, value: %s", pm, pm) //type: map[string]interface {}, value: map[name:test] } ``` ### EncodeByte

将data编码成字节切片

函数签名: ```go func EncodeByte(data any) ([]byte, error) ``` 例子: ```go package main import ( "fmt" "github.com/duke-git/lancet/convertor" ) func main() { byteData, _ := convertor.EncodeByte("abc") fmt.Println(byteData) //[]byte{6, 12, 0, 3, 97, 98, 99} } ``` ### DecodeByte

解码字节切片到目标对象,目标对象需要传入一个指针实例子

函数签名: ```go func DecodeByte(data []byte, target any) error ``` 例子: ```go package main import ( "fmt" "github.com/duke-git/lancet/convertor" ) func main() { var result string byteData := []byte{6, 12, 0, 3, 97, 98, 99} convertor.DecodeByte(byteData, &result) fmt.Println(result) //"abc" } ``` ### DeepClone

创建一个传入值的深拷贝, 无法克隆结构体的非导出字段。

函数签名: ```go func DeepClone[T any](src T) T ``` 示例: ```go package main import ( "fmt" "github.com/duke-git/lancet/convertor" ) func main() { type Struct struct { Str string Int int Float float64 Bool bool Nil interface{} unexported string } cases := []interface{}{ true, 1, 0.1, map[string]int{ "a": 1, "b": 2, }, &Struct{ Str: "test", Int: 1, Float: 0.1, Bool: true, Nil: nil, // unexported: "can't be cloned", }, } for _, item := range cases { cloned := convertor.DeepClone(item) isPointerEqual := &cloned == &item fmt.Println(cloned, isPointerEqual) } // Output: // true false // 1 false // 0.1 false // map[a:1 b:2] false // &{test 1 0.1 true } false } ``` ### CopyProperties

拷贝不同结构体之间的同名字段。使用json.Marshal序列化,需要设置dst和src struct字段的json tag。

函数签名: ```go func CopyProperties(dst, src interface{}) error ``` 示例: ```go package main import ( "fmt" "github.com/duke-git/lancet/convertor" ) func main() { type Disk struct { Name string `json:"name"` Total string `json:"total"` Used string `json:"used"` Percent float64 `json:"percent"` } type DiskVO struct { Name string `json:"name"` Total string `json:"total"` Used string `json:"used"` Percent float64 `json:"percent"` } type Indicator struct { Id string `json:"id"` Ip string `json:"ip"` UpTime string `json:"upTime"` LoadAvg string `json:"loadAvg"` Cpu int `json:"cpu"` Disk []Disk `json:"disk"` Stop chan bool `json:"-"` } type IndicatorVO struct { Id string `json:"id"` Ip string `json:"ip"` UpTime string `json:"upTime"` LoadAvg string `json:"loadAvg"` Cpu int64 `json:"cpu"` Disk []DiskVO `json:"disk"` } indicator := &Indicator{Id: "001", Ip: "127.0.0.1", Cpu: 1, Disk: []Disk{ {Name: "disk-001", Total: "100", Used: "1", Percent: 10}, {Name: "disk-002", Total: "200", Used: "1", Percent: 20}, {Name: "disk-003", Total: "300", Used: "1", Percent: 30}, }} indicatorVO := IndicatorVO{} err := convertor.CopyProperties(&indicatorVO, indicator) if err != nil { return } fmt.Println(indicatorVO.Id) fmt.Println(indicatorVO.Ip) fmt.Println(len(indicatorVO.Disk)) // Output: // 001 // 127.0.0.1 // 3 } ``` ### ToInterface

将反射值转换成对应的interface类型。

函数签名: ```go func ToInterface(v reflect.Value) (value interface{}, ok bool) ``` 示例: ```go package main import ( "fmt" "github.com/duke-git/lancet/convertor" ) func main() { val := reflect.ValueOf("abc") iVal, ok := convertor.ToInterface(val) fmt.Printf("%T\n", iVal) fmt.Printf("%v\n", iVal) fmt.Println(ok) // Output: // string // abc // true } ``` ### Utf8ToGbk

utf8编码转GBK编码。

函数签名: ```go func Utf8ToGbk(bs []byte) ([]byte, error) ``` 示例: ```go package main import ( "fmt" "github.com/duke-git/lancet/convertor" "github.com/duke-git/lancet/validator" ) func main() { utf8Data := []byte("hello") gbkData, _ := convertor.Utf8ToGbk(utf8Data) fmt.Println(utf8.Valid(utf8Data)) fmt.Println(validator.IsGBK(gbkData)) // Output: // true // true } ``` ### GbkToUtf8

GBK编码转utf8编码。

函数签名: ```go func GbkToUtf8(bs []byte) ([]byte, error) ``` 示例: ```go package main import ( "fmt" "github.com/duke-git/lancet/convertor" ) func main() { gbkData, _ := convertor.Utf8ToGbk([]byte("hello")) utf8Data, _ := convertor.GbkToUtf8(gbkData) fmt.Println(utf8.Valid(utf8Data)) fmt.Println(string(utf8Data)) // Output: // true // hello } ```