doubao7287 2019-09-23 10:46
浏览 144

正确将JSON转换为字符串

I am writing a function in which I am getting data in JSON format. I want to convert this JSON into string format then write in log file. Below is my code:

func JSONToString(logs map[string]interface{}){
    jsonLog, err := json.Marshal(logs)
    if err != nil {
        fmt.Println(err.Error())
    }
    jsonLogString := string(jsonLog[:len(jsonLog)])
    logfile := "/ServiceLogs/" + "UploadServiceLog_" + currentTime.Format("2006-01-02") + ".txt"
    jsonLogFile, err := os.OpenFile(logfile, os.O_RDWR|os.O_CREATE|os.O_APPEND, 0644)
    if err != nil {
        fmt.Println(err.Error())
    }
    defer jsonLogFile.Close()

    jsonLogFile.WriteString(jsonLogString + "
")
    jsonLogFile.Close()
}

Now what I get in logs is like

{"Errors":{},"RequestEnd":1569214715575873000,"ResponseTime":1569214715575.873,"ServiceName":"IMAGE_LISTING_SERVICE","Times":{"BasicValidationTime":0.150016,"ExtraValidationTime":0.002048,"FormParsingTime":0.479232,"ImagePgConnectionTime":0.31488,"RequestDecodingTime":0.009216}}

But I actually wanted this:

"{\"Errors\":{},\"RequestEnd\":1569214715575873000,\"ResponseTime\":1569214715575.873,\"ServiceName\":\"IMAGE_LISTING_SERVICE\",\"Times\":{\"BasicValidationTime\":0.150016,\"ExtraValidationTime\":0.002048,\"FormParsingTime\":0.479232,\"ImagePgConnectionTime\":0.31488,\"RequestDecodingTime\":0.009216}}"

I don't know how to achieve this.

  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥15 基于卷积神经网络的声纹识别
    • ¥15 Python中的request,如何使用ssr节点,通过代理requests网页。本人在泰国,需要用大陆ip才能玩网页游戏,合法合规。
    • ¥100 为什么这个恒流源电路不能恒流?
    • ¥15 有偿求跨组件数据流路径图
    • ¥15 写一个方法checkPerson,入参实体类Person,出参布尔值
    • ¥15 我想咨询一下路面纹理三维点云数据处理的一些问题,上传的坐标文件里是怎么对无序点进行编号的,以及xy坐标在处理的时候是进行整体模型分片处理的吗
    • ¥15 CSAPPattacklab
    • ¥15 一直显示正在等待HID—ISP
    • ¥15 Python turtle 画图
    • ¥15 stm32开发clion时遇到的编译问题