drxm72811 2018-04-18 18:35
浏览 149
已采纳

如何在保留引号的同时将数组连接到字符串中?

I have a string: {"isRegion":true, "tags":?}

Where I want to join an array of strings in place of ?, surrounded by quotes.

My current attempt doesn't quite work:

jsonStr := []byte(fmt.Sprintf(`{"isRegion":true, "tags":[%q]}, strings.Join(tags, `","`)))

The above gives the output: "tags":["prod\",\"stats"]

I instead need the quotes to persist without escaping: "tags":["prod","stats"]

  • 写回答

1条回答 默认 最新

  • dpmfur2635 2018-04-19 02:28
    关注

    Your tricky approach fixed:

    tags := []string{"prod", "stats"}
    
    jsonStr := []byte(fmt.Sprintf(`{"isRegion":true, "tags":["%s"]}`, 
        strings.Join(data, `", "`)))
    

    The easy and correct way:

    // This will be your JSON object
    type Whatever struct {
        // Field appears in JSON as key "isRegion"
        IsRegion bool     `json:"isRegion"` 
        Tags     []string `json:"tags"`
    }
    
    tags := []string{"prod", "stats"}
    w := Whatever{IsRegion: true, Tags: tags}
    
    // here is where we encode the object
    jsonStr, err := json.MarshalIndent(w, "", "  ")
    if err != nil {
        // Handle the error
    }
    
    fmt.Print(string(jsonStr))
    

    You can either use json.MarshalIndent or json.Marshal to encode JSON, and json.UnMarshal to decode. Check more info about this at the official documentation.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 oracle集群安装出bug
  • ¥15 关于#python#的问题:自动化测试
  • ¥15 教务系统账号被盗号如何追溯设备
  • ¥20 delta降尺度方法,未来数据怎么降尺度
  • ¥15 c# 使用NPOI快速将datatable数据导入excel中指定sheet,要求快速高效
  • ¥15 再不同版本的系统上,TCP传输速度不一致
  • ¥15 高德地图点聚合中Marker的位置无法实时更新
  • ¥15 DIFY API Endpoint 问题。
  • ¥20 sub地址DHCP问题
  • ¥15 delta降尺度计算的一些细节,有偿