wp-go/helper/maps/map.go

119 lines
2.0 KiB
Go
Raw Permalink Normal View History

2023-01-21 11:31:23 +00:00
package maps
2023-01-14 13:12:26 +00:00
2023-02-07 15:46:34 +00:00
import (
"encoding/json"
)
2023-01-14 13:12:26 +00:00
2023-01-17 15:18:31 +00:00
func StrAnyMapToStruct[T any, M any](m M) (r T, err error) {
2023-01-14 13:12:26 +00:00
str, err := json.Marshal(m)
if err != nil {
return
}
err = json.Unmarshal(str, &r)
return
}
2023-01-17 15:18:31 +00:00
func StructToAnyMap[K comparable, T any](s T) (r map[K]any, err error) {
2023-01-14 13:12:26 +00:00
marshal, err := json.Marshal(s)
if err != nil {
return
}
2023-01-17 15:18:31 +00:00
r = make(map[K]any)
2023-01-14 13:12:26 +00:00
err = json.Unmarshal(marshal, &r)
return
}
2023-01-21 11:31:23 +00:00
func FilterToSlice[T any, K comparable, V any](m map[K]V, fn func(K, V) (T, bool)) (r []T) {
2023-01-14 13:12:26 +00:00
for k, v := range m {
vv, ok := fn(k, v)
if ok {
r = append(r, vv)
}
}
return
}
2023-01-21 11:31:23 +00:00
// AnyAnyToStrAny map[any]any => map[string]any 方便json转换
func AnyAnyToStrAny(m map[any]any) (r map[string]any) {
r = make(map[string]any)
for k, v := range m {
kk, ok := k.(string)
if ok {
vv, ok := v.(map[any]any)
if ok {
2023-01-21 11:31:23 +00:00
r[kk] = AnyAnyToStrAny(vv)
} else {
r[kk] = v
}
}
}
return
}
2023-01-25 18:26:36 +00:00
func IsExists[K comparable, V any](m map[K]V, k K) bool {
_, ok := m[k]
return ok
}
2023-02-07 15:46:34 +00:00
func Keys[K comparable, V any](m map[K]V) []K {
return FilterToSlice(m, func(k K, v V) (K, bool) {
return k, true
})
}
func Values[K comparable, V any](m map[K]V) []V {
return FilterToSlice(m, func(k K, v V) (V, bool) {
return v, true
})
}
2023-01-25 18:26:36 +00:00
func Reduce[T, V any, K comparable](m map[K]V, fn func(K, V, T) T, r T) T {
for k, v := range m {
r = fn(k, v, r)
}
return r
}
2023-01-27 15:48:48 +00:00
func Replace[K comparable, V any](m map[K]V, mm ...map[K]V) map[K]V {
for _, n := range mm {
for k, v := range n {
_, ok := m[k]
if ok {
m[k] = v
}
}
}
return m
}
2023-02-09 15:15:10 +00:00
func Copy[K comparable, V any](m map[K]V) map[K]V {
r := make(map[K]V)
for k, v := range m {
r[k] = v
}
return r
}
func Merge[K comparable, V any](m ...map[K]V) map[K]V {
if len(m) < 1 {
panic("no map")
} else if len(m) < 2 {
return m[0]
}
mm := m[0]
for _, m2 := range m[1:] {
for k, v := range m2 {
mm[k] = v
}
}
return mm
}
2023-02-15 16:32:02 +00:00
func WithDefaultVal[K comparable, V any](m map[K]V, k K, defaults V) V {
vv, ok := m[k]
if ok {
return vv
}
return defaults
}