# Convertor Package convertor contains some functions for data type convertion.
## Source: - [https://github.com/duke-git/lancet/blob/main/convertor/convertor.go](https://github.com/duke-git/lancet/blob/main/convertor/convertor.go)
## Usage: ```go import ( "github.com/duke-git/lancet/v2/convertor" ) ```
## Index - [ColorHexToRGB](#ColorHexToRGB) - [ColorRGBToHex](#ColorRGBToHex) - [ToBool](#ToBool) - [ToBytes](#ToBytes) - [ToChar](#ToChar) - [ToInt](#ToInt) - [ToJson](#ToJson) - [ToString](#ToString) - [StructToMap](#StructToMap)
## Documentation ### ColorHexToRGB

Convert color hex to color rgb.

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

Convert color rgb to color hex.

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

Convert string to a boolean value. Use strconv.ParseBool

Signature: ```go func ToBool(s string) (bool, error) ``` Example: ```go package main import ( "fmt" "github.com/duke-git/lancet/v2/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

Convert interface to byte slice.

Signature: ```go func ToBytes(data any) ([]byte, error) ``` Example: ```go package main import ( "fmt" "github.com/duke-git/lancet/v2/convertor" ) func main() { bytesData, err := convertor.ToBytes("0") if err != nil { fmt.Println(err) } fmt.Println(bytesData) //[]bytes{3, 4, 0, 0} } ``` ### ToChar

Convert string to char slice.

Signature: ```go func ToChar(s string) []string ``` Example: ```go package main import ( "fmt" "github.com/duke-git/lancet/v2/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"} } ``` ### ToFloat

Convert interface to a float64 value. If param is a invalid floatable, will return 0 and error.

Signature: ```go func ToFloat(value any) (float64, error) ``` Example: ```go package main import ( "fmt" "github.com/duke-git/lancet/v2/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

Convert interface to a int64 value. If param is a invalid intable, will return 0 and error.

Signature: ```go func ToInt(value any) (int64, error) ``` Example: ```go package main import ( "fmt" "github.com/duke-git/lancet/v2/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

Convert interface to json string. If param can't be converted, will return "" and error.

Signature: ```go func ToJson(value any) (string, error) ``` Example: ```go package main import ( "fmt" "github.com/duke-git/lancet/v2/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

Convert interface to string.

Signature: ```go func ToString(value any) string ``` Example: ```go package main import ( "fmt" "github.com/duke-git/lancet/v2/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

Convert struct to map, only convert exported field, struct field tag `json` should be set.

Signature: ```go func StructToMap(value any) (map[string]any, error) ``` Example: ```go package main import ( "fmt" "github.com/duke-git/lancet/v2/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] } ```