优化 maps setstrval
This commit is contained in:
parent
03b448e70c
commit
a4274b74dd
@ -2,14 +2,18 @@ package maps
|
|||||||
|
|
||||||
import "strings"
|
import "strings"
|
||||||
|
|
||||||
func GetStrAnyVal[T any](m map[string]any, key string) (r T, o bool) {
|
func GetStrAnyVal[T any](m map[string]any, key string, delimiter ...string) (r T, o bool) {
|
||||||
k := strings.Split(key, ".")
|
separator := "."
|
||||||
|
if len(delimiter) > 0 && delimiter[0] != "" {
|
||||||
|
separator = delimiter[0]
|
||||||
|
}
|
||||||
|
k := strings.Split(key, separator)
|
||||||
if len(k) > 1 {
|
if len(k) > 1 {
|
||||||
val, ok := m[k[0]]
|
val, ok := m[k[0]]
|
||||||
if ok {
|
if ok {
|
||||||
vx, ok := val.(map[string]any)
|
vx, ok := val.(map[string]any)
|
||||||
if ok {
|
if ok {
|
||||||
r, o = GetStrAnyVal[T](vx, strings.Join(k[1:], "."))
|
r, o = GetStrAnyVal[T](vx, strings.Join(k[1:], separator))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@ -107,31 +111,41 @@ func GetAnyAnyValWithDefaults[T any](m map[any]any, defaults T, key ...any) (r T
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
func RecursiveSetStrVal[T any](m map[string]any, k string, v T) {
|
func RecursiveSetStrVal[T any](m map[string]any, k string, v T, delimiter ...string) {
|
||||||
kk := strings.Split(k, ".")
|
del := "."
|
||||||
|
if len(delimiter) > 0 && delimiter[0] != "" {
|
||||||
|
del = delimiter[0]
|
||||||
|
}
|
||||||
|
kk := strings.Split(k, del)
|
||||||
if len(kk) < 1 {
|
if len(kk) < 1 {
|
||||||
return
|
return
|
||||||
} else if len(kk) < 2 {
|
} else if len(kk) < 2 {
|
||||||
m[k] = v
|
m[k] = v
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
for i, _ := range kk[0 : len(kk)-1] {
|
mm, ok := GetStrAnyVal[map[string]any](m, strings.Join(kk[0:len(kk)-1], del))
|
||||||
key := strings.Join(kk[0:i+1], ".")
|
if ok {
|
||||||
mm, ok := GetStrAnyVal[map[string]any](m, key)
|
|
||||||
if !ok {
|
|
||||||
mm = map[string]any{}
|
|
||||||
preKey := strings.Join(kk[0:i], ".")
|
|
||||||
if preKey == "" {
|
|
||||||
RecursiveSetStrVal(m, key, mm)
|
|
||||||
} else {
|
|
||||||
m, _ := GetStrAnyVal[map[string]any](m, preKey)
|
|
||||||
RecursiveSetStrVal(m, kk[i], mm)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
key := strings.Join(kk[0:len(kk)-1], ".")
|
|
||||||
mm, _ := GetStrAnyVal[map[string]any](m, key)
|
|
||||||
mm[kk[len(kk)-1]] = v
|
mm[kk[len(kk)-1]] = v
|
||||||
|
return
|
||||||
|
}
|
||||||
|
mx, ok := GetStrAnyVal[map[string]any](m, kk[0])
|
||||||
|
if !ok {
|
||||||
|
m[kk[0]] = map[string]any{}
|
||||||
|
mx = m[kk[0]].(map[string]any)
|
||||||
|
}
|
||||||
|
for i, _ := range kk[0 : len(kk)-2] {
|
||||||
|
key := kk[i+1]
|
||||||
|
mm, ok := mx[key]
|
||||||
|
if !ok {
|
||||||
|
mmm := map[string]any{}
|
||||||
|
mx[key] = mmm
|
||||||
|
mx = mmm
|
||||||
|
|
||||||
|
} else {
|
||||||
|
mx = mm.(map[string]any)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
mx[kk[len(kk)-1]] = v
|
||||||
}
|
}
|
||||||
|
|
||||||
func RecursiveSetAnyVal[T any](m map[any]any, v T, k ...any) {
|
func RecursiveSetAnyVal[T any](m map[any]any, v T, k ...any) {
|
||||||
|
@ -267,6 +267,22 @@ func TestRecursiveSetStrVal(t *testing.T) {
|
|||||||
v: 1,
|
v: 1,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
name: "t2",
|
||||||
|
args: args[int]{
|
||||||
|
m: map[string]any{"aa": map[string]any{}},
|
||||||
|
k: "aa.bb.cc",
|
||||||
|
v: 1,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "t3",
|
||||||
|
args: args[int]{
|
||||||
|
m: map[string]any{"aa": map[string]any{"bb": map[string]any{}}},
|
||||||
|
k: "aa.bb.cc",
|
||||||
|
v: 1,
|
||||||
|
},
|
||||||
|
},
|
||||||
}
|
}
|
||||||
target := map[string]any{"aa": map[string]any{"bb": map[string]any{"cc": 1}}}
|
target := map[string]any{"aa": map[string]any{"bb": map[string]any{"cc": 1}}}
|
||||||
for _, tt := range tests {
|
for _, tt := range tests {
|
||||||
|
Loading…
Reference in New Issue
Block a user