Слияние кода завершено, страница обновится автоматически
package ffmt
import (
"strconv"
"strings"
)
func Flatten(nested map[string]interface{}) map[string]interface{} {
if nested == nil {
return nested
}
flatmap := map[string]interface{}{}
var prefixes []string
flatten(0, flatmap, nested, prefixes)
return flatmap
}
func flatten(deep int, flatMap map[string]interface{}, nested interface{}, prefixes []string) {
switch t := nested.(type) {
case map[string]interface{}:
for k, v := range t {
flatten(deep+1, flatMap, v, append(prefixes, k))
}
case []interface{}:
for i, v := range t {
flatten(deep+1, flatMap, v, append(prefixes, strconv.Itoa(i)))
}
default:
key := strings.Join(prefixes, ".")
flatMap[key] = t
}
}
Вы можете оставить комментарий после Вход в систему
Неприемлемый контент может быть отображен здесь и не будет показан на странице. Вы можете проверить и изменить его с помощью соответствующей функции редактирования.
Если вы подтверждаете, что содержание не содержит непристойной лексики/перенаправления на рекламу/насилия/вульгарной порнографии/нарушений/пиратства/ложного/незначительного или незаконного контента, связанного с национальными законами и предписаниями, вы можете нажать «Отправить» для подачи апелляции, и мы обработаем ее как можно скорее.
Опубликовать ( 0 )