ホームページ >バックエンド開発 >Golang >golang は json コメントを処理します

golang は json コメントを処理します

王林
王林オリジナル
2023-05-15 09:33:07668ブラウズ

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 ファイルの作成と管理をより便利にするために、いくつかの注釈ルールを指定する必要もあります。ここでは、いくつかのコメント ルールへの参照を示します。

  1. 単一行のコメントは、「//」で始まり、行の終わりで終わります。

    {
    "name": "test", // 名称
    "age": 22 // 年龄
    }
  2. 複数行のコメントは「/」で始まり「/」で終わります。

    {
    "name": "test", /* 名称 */
    "age": 22 /* 年龄 */
    }
  3. コメントは、文字列、数値、ブール値以外のどこにでも記述できます。

4. 概要

コメントを含む json ファイルを golang で処理するのは面倒かもしれませんが、サードパーティのライブラリまたはカスタム パーサーを使用してこの問題を解決できます。カスタム パーサーは最も柔軟な処理を実現できますが、追加の開発コストが必要になります。より適切に適用するには、アノテーション ルールも標準化する必要があります。

以上がgolang は json コメントを処理しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。