Есть ли способ перебрать все ключи и значения json и тем самым подтвердить и заменить конкретное значение сопоставленным путем или сопоставленным сравниваемым ключом или значением и одновременно создать новый интерфейс из json после подтверждения с помощью нового значения ключа в Golang .

В этом примере, который я видел, перебираются все значения https://play.golang.org/p/xtiT2iGocBg но я понятия не имею о замене значений совпадающим путем или значением

1
General Omosco 23 Сен 2018 в 16:16

2 ответа

Лучший ответ

В заключение! Я выполнил полную спецификацию того, что искал !!

https://play.golang.org/p/eN4-FjaQS97

   package main

import (
    "encoding/json"
    "fmt"
)

func main() {
    b := []byte(`
        {
        "iw":{"Ie":{"Itye":{"e":"eIe"}}},
"InnerJSON2":"NoneValue",
    "outterJSON":{
        "innerJSON1":{
            "value1":10,
            "value2":22
            ,
            "InnerInnerArray": [ "test1" , "test2"],
            "InnerInnerJSONArray": [ {"fld1" : "val1"} , {"fld2" : "val2"} ]
            },
            "InnerJSON2":"NoneValue"
        }
    }
    `)

    f := map[string]interface{}{}
    if err := json.Unmarshal(b, &f); err != nil {
        panic(err)
    }

    verifyJSON(f)
    data, _ := json.MarshalIndent(f, "", "  ")
    fmt.Println(string(data))
}

func verifyJSON(bv interface{}) {

    var dumpJSON func(v interface{}, kn string)

    dumpJSON = func(v interface{}, kn string) {
        iterMap := func(x map[string]interface{}, root string) {

            var knf string
            if root == "root" {
                knf = "%v/%v"
            } else {
                knf = "%v/%v"
            }
            for k, v := range x {

                switch vv := v.(type) {

                case map[string]interface{}:

                    fmt.Printf("%s => (map[string]interface{}) ...\n", fmt.Sprintf(knf, root, k))

                case []interface{}:
                    fmt.Printf("%s => ([]interface{}) ...\n", fmt.Sprintf(knf, root, k))
                default:
                    fmt.Printf("%s => %v\n", fmt.Sprintf(knf, root, k), vv)
                    x[k] = "rgk"
                }
                dumpJSON(v, fmt.Sprintf(knf, root, k))
            }
        }

        iterSlice := func(x []interface{}, root string) {
            var knf string
            if root == "root" {
                knf = "%v/%v"

            } else {
                knf = "%v/%v"
            }
            for k, v := range x {

                switch vv := v.(type) {

                case map[string]interface{}:

                    fmt.Printf("%s => (map[string]interface{}) ...\n", fmt.Sprintf(knf, root, k))

                case []interface{}:
                    fmt.Printf("%s => ([]interface{}) ...\n", fmt.Sprintf(knf, root, k))
                default:

                    fmt.Printf("%s => %v\n", fmt.Sprintf(knf, root, k), vv)

                    x[k] = "rg"
                }

                dumpJSON(v, fmt.Sprintf(knf, root, k))
            }
        }

        switch vv := v.(type) {
        case map[string]interface{}:
            iterMap(vv, kn)
        case []interface{}:
            iterSlice(vv, kn)
        default:

        }
    }
    dumpJSON(bv, "root")
}
1
General Omosco 13 Фев 2019 в 21:10

Наконец-то мне удалось получить ключи / значения и в то же время я могу заменить любые значения или ключи сейчас, но последний шаг, с которым я сейчас борюсь, - это как я могу получить пути aMap[key] и anArray[i] для всех значений соответственно , Например, "test2": "TEST EACH REPLACE " имеет путь outterJSON.innerJSON1.nnerInnerArray.1.test2, но может быть в любом формате.

https://play.golang.org/p/TNkonE8AkoJ

package main

import (
    "encoding/json"
    "fmt"   
)
 var co=""
func main() {
    //Creating the maps for JSON
    m := map[string]interface{}{}

    //Parsing/Unmarshalling JSON encoding/json
    err := json.Unmarshal([]byte(input), &m)

    if err != nil {
        panic(err)
    }
    parseMap(m)

    fmt.Println(co)

    data, _ := json.MarshalIndent(m,"", "  ")
    fmt.Println(string(data))
}

func parseMap(aMap map[string]interface{}) {
    for key, val := range aMap {
        switch concreteVal := val.(type) {
        case map[string]interface{}:

        co += key+"."
            fmt.Println(key+"NwHN")
            parseMap(val.(map[string]interface{}))

        case []interface{}:
        co += key+"."
            fmt.Println(key+"NHN")
            parseArray(val.([]interface{}))

        default:

        fmt.Println("OOOOO")
        aMap[key]="TEST EACH REPLACE "
            fmt.Println(key, "v:", concreteVal)

        }
    }
}

func parseArray(anArray []interface{}) {
    for i, val := range anArray {
        switch concreteVal := val.(type) {
        case map[string]interface{}:

            fmt.Println("Indexr:", i)
            parseMap(val.(map[string]interface{}))

        case []interface{}:

            fmt.Println("Indexb:", i)
            parseArray(val.([]interface{}))


        default:
        anArray[i]= "TEST EACH REPLACE ARR"
            fmt.Println("Index", i, ":", concreteVal)

        }
    }
}

const input = `
{
"ouj":"ou",
    "outterJSON":{
        "innerJSON1":{
            "value1":10,
            "value2":22
            ,
            "InnerInnerArray": [ "test1" , {"test2":"valtest2"}],
            "InnerInnerJSONArray": [ {"fld1" : "val1"} , {"fld2" : "val2"} ]
            },
            "InnerJSON2":"NoneValue"
        }
    }
    `
1
General Omosco 23 Сен 2018 в 21:07