3 回答

TA貢獻1836條經驗 獲得超13個贊
我會像你一樣做,做一些調整來修正錯別字
import (
"fmt"
"strconv"
"strings"
)
func main() {
list := []int{1,2,3}
var list2 []string
for _, x := range list {
list2 = append(list2, strconv.Itoa(x * 2)) // note the = instead of :=
}
str := strings.Join(list2, ", ")
fmt.Println(str)
}

TA貢獻1817條經驗 獲得超14個贊
這是一個古老的問題,但在我的 Google 搜索中排名靠前,我找到了我認為對 OP 和其他到達這里尋找相同內容的人有幫助的信息。
有一種更短的方法,盡管您必須自己編寫 map 函數。
在 go 中,func是一種類型,它允許您編寫一個函數,該函數接受主題切片和函數作為輸入,并在該切片上迭代,應用該函數。
查看Map此 Go by Example 頁面底部附近的功能:https : //gobyexample.com/collection-functions
我已將其包含在此處以供參考:
func Map(vs []string, f func(string) string) []string {
vsm := make([]string, len(vs))
for i, v := range vs {
vsm[i] = f(v)
}
return vsm
}
然后你可以這樣稱呼它:
fmt.Println(Map(strs, strings.ToUpper))
所以,是的:您正在尋找的更短的方式存在,盡管它沒有內置在語言本身中。

TA貢獻1773條經驗 獲得超3個贊
找到了定義通用地圖數組函數的方法
func Map(t interface{}, f func(interface{}) interface{} ) []interface{} {
switch reflect.TypeOf(t).Kind() {
case reflect.Slice:
s := reflect.ValueOf(t)
arr := make([]interface{}, s.Len())
for i := 0; i < s.Len(); i++ {
arr[i] = f(s.Index(i).Interface())
}
return arr
}
return nil
}
origin := []int{4,5,3}
newArray := Map(origin, func(item interface{}) interface{} { return item.(int) + 1})
- 3 回答
- 0 關注
- 232 瀏覽
添加回答
舉報