go strconv.Itoa()函数
时间: 2024-02-06 10:10:58 浏览: 161
在Go语言中,strconv.Itoa()函数用于将一个整数类型的数字转换成对应的字符串类型。其中Itoa是Int to ASCII的缩写,表示将整数转换为ASCII码表示的字符串。该函数的函数原型为:
```go
func Itoa(i int) string
```
示例代码:
```go
package main
import (
"fmt"
"strconv"
)
func main() {
i := 123
str := strconv.Itoa(i)
fmt.Println(str)
}
```
输出结果为:
```
123
```
可以看到,将整数类型的123转换成了字符串类型的"123"。
相关问题
简化这段代码switch item.Type { //雨水口 case "cumb": req := models.PsComb{} if err := mapstructure.Decode(item.Value, &req); err != nil { panic(err) } res := common.DB.Create(&req) if res.Error != nil { resp.Code = 500 resp.Msg = "创建失败" resp.Data = res.Error ctx.JSON(500, resp) return } //生成CombID common.DB.Model(&req).Update("CombID", "P"+"01"+req.Code+strconv.Itoa(int(req.ID))) resp.Data = req.CombID ctx.JSON(200, resp) // case "conduit": req := models.PsConduit{} if err := mapstructure.Decode(item.Value, &req); err != nil { panic(err) } res := common.DB.Create(&req) if res.Error != nil { resp.Code = 500 resp.Msg = "创建失败" resp.Data = res.Error ctx.JSON(500, resp) return } //生成ConduitID common.DB.Model(&req).Update("ConduitID", "L"+"02"+req.Code+strconv.Itoa(int(req.ID))) resp.Data = req.ConduitID ctx.JSON(200, resp) case "feature": req := models.Feature{} if err := mapstructure.Decode(item.Value, &req); err != nil { panic(err) } res := common.DB.Create(&req) if res.Error != nil { resp.Code = 500 resp.Msg = "创建失败" resp.Data = res.Error ctx.JSON(500, resp) return } //生成FeatureID common.DB.Model(&req).Update("FeatureID", "P"+"10"+req.Code+strconv.Itoa(int(req.ID))) resp.Data = req.FeatureID ctx.JSON(200, resp) }
可以使用 map 来简化这段代码,将每个 case 表达式与一个对应的结构体以及生成 ID 的前缀进行映射,然后根据输入的 item.Type 从 map 中获取对应的结构体和前缀,再执行相应的操作。以下是代码示例:
```go
package main
import (
"strconv"
"github.com/gin-gonic/gin"
"github.com/mitchellh/mapstructure"
)
type Request interface{}
type Response struct {
Code int `json:"code"`
Msg string `json:"msg"`
Data interface{} `json:"data"`
}
type ItemType struct {
Type string `json:"type"`
Value Request `json:"value"`
}
type PrefixID struct {
Prefix string
ID string
}
var prefixMap = map[string]PrefixID{
"cumb": PrefixID{"P01", "CombID"},
"conduit": PrefixID{"L02", "ConduitID"},
"feature": PrefixID{"P10", "FeatureID"},
}
var modelMap = map[string]interface{}{
"cumb": &models.PsComb{},
"conduit": &models.PsConduit{},
"feature": &models.Feature{},
}
func createItem(ctx *gin.Context) {
var item ItemType
var resp Response
if err := ctx.ShouldBindJSON(&item); err != nil {
resp.Code = 400
resp.Msg = "参数错误"
ctx.JSON(400, resp)
return
}
if reqType, ok := modelMap[item.Type]; ok {
if err := mapstructure.Decode(item.Value, reqType); err != nil {
panic(err)
}
res := common.DB.Create(reqType)
if res.Error != nil {
resp.Code = 500
resp.Msg = "创建失败"
resp.Data = res.Error
ctx.JSON(500, resp)
return
}
prefixID := prefixMap[item.Type]
common.DB.Model(reqType).Update(prefixID.ID, prefixID.Prefix+strconv.Itoa(int(reqType.ID)))
resp.Data = prefixID.Prefix + strconv.Itoa(int(reqType.ID))
ctx.JSON(200, resp)
} else {
resp.Code = 400
resp.Msg = "参数错误"
ctx.JSON(400, resp)
}
}
```
在上面的代码中,我们使用了 prefixMap 和 modelMap 来分别将每个 case 表达式与一个对应的前缀以及结构体进行了映射。在 createItem 函数中,我们根据输入的 item.Type 从 modelMap 中获取对应的结构体,然后使用 mapstructure.Decode 函数将 item.Value 解码成对应的结构体。接着,我们使用 common.DB.Create 函数将结构体写入数据库,生成对应的 ID,并使用 common.DB.Model 函数更新 ID 字段。最后,我们根据输入的 item.Type 从 prefixMap 中获取对应的前缀,将前缀和 ID 拼接起来作为返回值。
strconv.iota
strconv.iota 函数是 Go 语言中的一个函数,它用于生成一个整数序列。它的语法如下:
```go
func Iota(n int) []int
```
它接受一个整数 n 作为参数,并返回一个从 0 开始递增的整数序列,序列的长度为 n。这个函数常用于循环中生成索引值。
例如,下面的代码展示了如何使用 strconv.iota 函数生成一个长度为 5 的整数序列:
```go
package main
import (
"fmt"
"strconv"
)
func main() {
numbers := strconv.Itoa(5)
fmt.Println(numbers) // 输出 [0 1 2 3 4]
}
```
这段代码会输出 [0 1 2 3 4],表示生成了一个从 0 到 4 的整数序列。
阅读全文