golang の開発プロセスでは、json を処理する必要がある状況によく遭遇します。しかし、json内のコメントの処理は非常に面倒な問題です。 json ファイルでコメントを使用すると、開発者がコードをよりよく理解して管理できるようになりますが、標準の json ライブラリはコメントをサポートしていません。では、この問題をどうやって解決すればよいでしょうか?
1. golang 標準ライブラリは json コメントを処理できません
最初に理解する必要があるのは、json にコメントを追加したとしても、golang 標準 json ライブラリは json 内のコメントを処理できないということです。 json を使用する .Unmarshal() 関数も解析できません。したがって、この問題を解決するには他の解決策を見つける必要があります。
2. サードパーティ ライブラリ
検索すると、encorehu/json-annotate、jbarratt/jsonparser、pebbe/util などのサードパーティ ライブラリを見つけることができます。これらはすべて json アノテーションの処理をサポートできますが、使用するのが面倒で、カプセル化や独自の二次開発が必要になる場合があります。
3. カスタム パーサー
3 番目の方法は、カスタム パーサーを使用することで、json ファイル内のコメントを処理する独自のパーサーを作成できます。この方法は最も柔軟で、実際のニーズに応じてカスタマイズできます。
以下は、golang カスタム パーサーを使用してコメントを含む json ファイルを解析するためのサンプル コードです:
package main import ( "bufio" "fmt" "io" "os" "unicode" ) type JsonScanner struct { r *bufio.Reader } func NewJsonScanner(r io.Reader) *JsonScanner { return &JsonScanner{ r: bufio.NewReader(r), } } func (s *JsonScanner) read() (rune, error) { char, _, err := s.r.ReadRune() return char, err } func (s *JsonScanner) unread() error { return s.r.UnreadRune() } func (s *JsonScanner) Scan() (string, error) { var c rune var err error var token []rune var inComment bool for { c, err = s.read() if err != nil { break } if !inComment { if unicode.IsSpace(c) || c == ',' || c == ':' || c == '{' || c == '}' || c == '[' || c == ']' || c == '"' { if err = s.unread(); err != nil { break } break } } token = append(token, c) if c == '/' { nextChar, err := s.read() if err == nil && nextChar == '/' { inComment = true } else { err = s.unread() break } } else if c == ' ' { inComment = false } } if inComment { return "", fmt.Errorf("comment not closed") } return string(token), err } func parseJson(r io.Reader) error { scanner := NewJsonScanner(r) for { token, err := scanner.Scan() if err == io.EOF { break } else if err != nil { return err } fmt.Println(token) } return nil } func main() { f, _ := os.Open("test.json") defer f.Close() if err := parseJson(f); err != nil { fmt.Printf("parseJson error: %v ", err) } }
4. コメント ルール
カスタム パーサーはコメントを処理できますが、注釈を含む json ファイルの作成と管理をより便利にするために、いくつかの注釈ルールを指定する必要もあります。ここでは、いくつかのコメント ルールへの参照を示します。
単一行のコメントは、「//」で始まり、行の終わりで終わります。
{ "name": "test", // 名称 "age": 22 // 年龄 }
複数行のコメントは「/」で始まり「/」で終わります。
{ "name": "test", /* 名称 */ "age": 22 /* 年龄 */ }
4. 概要
コメントを含む json ファイルを golang で処理するのは面倒かもしれませんが、サードパーティのライブラリまたはカスタム パーサーを使用してこの問題を解決できます。カスタム パーサーは最も柔軟な処理を実現できますが、追加の開発コストが必要になります。より適切に適用するには、アノテーション ルールも標準化する必要があります。
以上がgolang は json コメントを処理しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。