사람이 읽을 수 있는 JSON 출력을 위해 Go의 인코딩/JSON 패키지 사용
파이핑 시 사람이 읽을 수 있는 JSON 출력을 생성해야 하는 어려움에 직면했다고 언급하셨습니다. jq를 통한 foo 명령의 결과. 이 목적을 위해 특별히 설계된 알려진 오픈 소스 jq 래퍼는 없지만 Go에 내장된 인코딩/json 패키지를 활용하여 원하는 결과를 얻을 수 있습니다.
json.MarshalIndent() 및 Encoder 활용 .SetIndent()
json.MarshalIndent() 함수는 JSON을 인코딩하는 편리한 방법을 제공합니다. 형식화된 문자열로 값을 반환합니다. 원하는 접두사와 들여쓰기를 지정하면 사람이 읽을 수 있는 출력을 생성할 수 있습니다. 마찬가지로 json.Encoder의 SetIndent() 메서드를 사용하면 JSON 출력에 대한 들여쓰기를 설정할 수 있습니다.
예제 코드
다음은 json.MarshalIndent 사용법을 보여주는 예입니다. ():
package main import ( "encoding/json" ) func main() { m := map[string]interface{}{"id": "uuid1", "name": "John Smith"} data, err := json.MarshalIndent(m, "", " ") if err != nil { panic(err) } fmt.Println(string(data)) }
다음을 사용할 수도 있습니다. 들여쓰기를 제어하는 json.NewEncoder:
package main import ( "encoding/json" "os" ) func main() { enc := json.NewEncoder(os.Stdout) enc.SetIndent("", " ") m := map[string]interface{}{"id": "uuid1", "name": "John Smith"} if err := enc.Encode(m); err != nil { panic(err) } }
미리 생성된 JSON 텍스트 형식 지정
미리 생성된 JSON 텍스트가 있는 경우 json.Indent를 활용할 수 있습니다. () 함수를 사용하여 형식을 지정합니다.
package main import ( "bytes" "encoding/json" ) func main() { src := `{"id":"uuid1","name":"John Smith"}` dst := &bytes.Buffer{} if err := json.Indent(dst, []byte(src), "", " "); err != nil { panic(err) } fmt.Println(dst.String()) }
이러한 기술을 사용하면 쉽게 외부 jq 래퍼 없이도 Go 프로그램 내에서 사람이 읽을 수 있는 JSON 출력을 얻을 수 있습니다.
위 내용은 Go의 `encoding/json` 패키지는 어떻게 사람이 읽을 수 있는 JSON 출력을 생성할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!