JSON 转 Proto 工具(支持嵌套与注释解析)

JSON 转 Proto 工具(支持嵌套与注释解析)

平时在做 gRPC 或者微服务的时候,经常需要写 .proto 文件。

但现实情况是,大多数时候我们手里已经有一份 JSON 数据结构了,再去手写 proto,其实有点重复劳动。

最近整理了一个 JSON 转 Proto 的工具,主要就是把这一步自动化,同时补了一些实际开发里比较有用的能力,比如嵌套解析、注释保留这些。


功能点

1. 嵌套 JSON 自动解析

支持递归解析 JSON 结构。

如果 JSON 里有对象嵌套、数组嵌套,会自动拆分成多个 message,并建立引用关系,不需要手动去拆结构。


2. 数组自动识别为 repeated

像这种结构:

json 复制代码
{
  "list": [
    {
      "name": "test"
    }
  ]
}

会自动生成:

proto 复制代码
repeated Item list = 1;

基本符合 proto 的使用习惯。


3. 注释解析(比较实用)

如果 JSON 里带有注释:

json 复制代码
{
  "name": "test", // 姓名
  "age": 10 // 年龄
}

生成的 proto 会保留这些注释:

proto 复制代码
message GenerateObj {
  string name = 1; // 姓名
  int32 age = 2; // 年龄
}

这一点在接口文档或者多人协作时还是挺有用的。


4. JSON 格式校验

在转换之前会先做一层 JSON 校验。

如果有语法问题,会提示具体错误位置,避免生成错误的 proto。


示例

输入:

json 复制代码
{
  "name": "test", // 姓名
  "age": 10, // 年龄
  "addr": "四川成都", // 地址
  "cls_info": [
    {
      "name": "篮球班", // 班名
      "teacher": "张老师" // 老师
    },
    {
      "name": "美术班",
      "teacher": "李老师"
    }
  ]
}

输出:

proto 复制代码
message ClsInfo {
  string name = 1; // 班名
  string teacher = 2; // 老师
}

message GenerateObj {
  string name = 1; // 姓名
  int32 age = 2; // 年龄
  string addr = 3; // 地址
  repeated ClsInfo cls_info = 4; // 班级
}

使用场景

  • 从已有 JSON 快速生成 proto
  • gRPC 接口定义
  • 数据结构建模
  • 接口文档辅助生成

地址

https://gotool.top


一点说明

这个工具主要解决的是一件小事:

把「JSON → Proto」这一步做得更省事一点。

顺带把几个常见问题一起处理了:

  • 嵌套结构自动拆
  • 数组自动转 repeated
  • 注释尽量保留

如果你平时会写 proto,这一步其实能省不少时间。

相关推荐
A__tao14 小时前
JSON 转 Java 实体类工具(支持嵌套与注释解析)
java·python·json
迷路爸爸18017 小时前
VSCode / Cursor 中 LaTeX Workshop 的 settings.json 配置:编译与 SyncTeX 跳转
ide·vscode·json·latex
吴声子夜歌1 天前
Node.js——JSON-Server轻量级RESTful API
node.js·json·restful·json-server
呆萌的代Ma2 天前
解决n8n的输入内容报错JSON parameter needs to be valid JSON
json·n8n
ID_180079054734 天前
Python 实现亚马逊商品详情 API 数据准确性校验(极简可用 + JSON 参考)
java·python·json
代码AI弗森4 天前
配置文件战争:TOML/YAML/JSON 为何成为不同框架的“专属标配”?
json
lifewange5 天前
CNode API v1 完整接口文档(JSON 规范整理)
java·前端·json
测试修炼手册5 天前
[测试技术] 深入理解 JSON Web Token (JWT)
前端·json
九转成圣5 天前
Java 性能优化实战:如何将海量扁平数据高效转化为类目字典树?
java·开发语言·json