JSON 元组数组的架构
JSON Schema for Array of tuples
提前致谢。
我是 JSON & JSON 模式的新手。尝试为元组数组生成 JSON 架构。但它不会像所有类似类型的元组的循环一样验证多个记录。
下面是 json 示例。
{
"Data":
[
[ 100, "Test", 2.5 ],
[ 101, "Test1", 3.5]
]
}
我已经使用站点 jsonschema.net 生成了架构,如下所示
{
"$schema": "http://json-schema.org/draft-04/schema#",
"id": "http://jsonschema.net",
"type": "object",
"properties": {
"Data": {
"id": "http://jsonschema.net/Data",
"type": "array",
"items": [
{
"id": "http://jsonschema.net/Data/0",
"type": "array",
"items": [
{
"id": "http://jsonschema.net/Data/0/0",
"type": "integer"
},
{
"id": "http://jsonschema.net/Data/0/1",
"type": "string"
},
{
"id": "http://jsonschema.net/Data/0/2",
"type": "number"
}
],
"required": [
"0",
"1",
"2"
]
},
{
"id": "http://jsonschema.net/Data/1",
"type": "array",
"items": [
{
"id": "http://jsonschema.net/Data/1/0",
"type": "integer"
},
{
"id": "http://jsonschema.net/Data/1/1",
"type": "string"
},
{
"id": "http://jsonschema.net/Data/1/2",
"type": "number"
}
]
}
],
"required": [
"0",
"1"
]
}
},
"required": [
"Data"
]
}
如果您看到,它正在为每个相似类型的元组创建模式。请帮助我创建一个模式以通用方式验证每个元组。元组计数可能会有所不同。
如果您希望内部数组包含同类的所有项目,您可以使用对象而不是数组。以下架构验证您的示例:
{
"type" : "object",
"properties" : {
"Data" : {
"type" : "array",
"items" : {
"type" : "array",
"items" : [{
"type" : "integer"
}, {
"type" : "string"
}, {
"type" : "number"
}
]
}
}
}
}
我已经测试过了here。
{
"Table1": {
"Data": [
[
100,
"Test",
2.5
],
[
101,
"Test1",
5.5
]
]
}
}
上面是示例 json 其架构如下
{
"$schema": "http://json-schema.org/draft-04/schema#",
"id": "http://jsonschema.net",
"type": "object",
"properties": {
"Table1": {
"id": "http://jsonschema.net/Table1",
"type": "object",
"properties": {
"Data": {
"id": "http://jsonschema.net/Table1/Data",
"type": "array",
"items": {
"type": "array",
"items": [
{
"id": "http://jsonschema.net/Table1/Data/0/0",
"type": "integer"
},
{
"id": "http://jsonschema.net/Table1/Data/0/1",
"type": "string"
},
{
"id": "http://jsonschema.net/Table1/Data/0/2",
"type": "number"
}
],
"additionalItems": false,
"required": [
"0",
"1",
"2"
]
}
}
},
"required": [
"Data"
]
}
}
}
此架构适用于所有数据行,但它所需的 属性 不知何故不起作用。尽管我期待所有 3 列数据。它也接受具有 1 或 2 列的行。
如果有人有任何想法。请指正。
[ 101 ], [ 101, "TEST3" ]
也是预期之外的有效数据记录。
JSON schema 有一个新的元组语法,以前建议的解决方案现在可以这样写:
{
"type": "object",
"properties": {
"Data": {
"type": "array",
"items": [
{
"type": "array",
"prefixItems": [
{ "type": "integer" },
{ "type": "string" },
{ "type": "integer" }
],
"minItems": 3,
"items": false
}
]
}
},
"required": [
"Data"
]
}
提前致谢。
我是 JSON & JSON 模式的新手。尝试为元组数组生成 JSON 架构。但它不会像所有类似类型的元组的循环一样验证多个记录。 下面是 json 示例。
{
"Data":
[
[ 100, "Test", 2.5 ],
[ 101, "Test1", 3.5]
]
}
我已经使用站点 jsonschema.net 生成了架构,如下所示
{
"$schema": "http://json-schema.org/draft-04/schema#",
"id": "http://jsonschema.net",
"type": "object",
"properties": {
"Data": {
"id": "http://jsonschema.net/Data",
"type": "array",
"items": [
{
"id": "http://jsonschema.net/Data/0",
"type": "array",
"items": [
{
"id": "http://jsonschema.net/Data/0/0",
"type": "integer"
},
{
"id": "http://jsonschema.net/Data/0/1",
"type": "string"
},
{
"id": "http://jsonschema.net/Data/0/2",
"type": "number"
}
],
"required": [
"0",
"1",
"2"
]
},
{
"id": "http://jsonschema.net/Data/1",
"type": "array",
"items": [
{
"id": "http://jsonschema.net/Data/1/0",
"type": "integer"
},
{
"id": "http://jsonschema.net/Data/1/1",
"type": "string"
},
{
"id": "http://jsonschema.net/Data/1/2",
"type": "number"
}
]
}
],
"required": [
"0",
"1"
]
}
},
"required": [
"Data"
]
}
如果您看到,它正在为每个相似类型的元组创建模式。请帮助我创建一个模式以通用方式验证每个元组。元组计数可能会有所不同。
如果您希望内部数组包含同类的所有项目,您可以使用对象而不是数组。以下架构验证您的示例:
{
"type" : "object",
"properties" : {
"Data" : {
"type" : "array",
"items" : {
"type" : "array",
"items" : [{
"type" : "integer"
}, {
"type" : "string"
}, {
"type" : "number"
}
]
}
}
}
}
我已经测试过了here。
{
"Table1": {
"Data": [
[
100,
"Test",
2.5
],
[
101,
"Test1",
5.5
]
]
}
}
上面是示例 json 其架构如下
{
"$schema": "http://json-schema.org/draft-04/schema#",
"id": "http://jsonschema.net",
"type": "object",
"properties": {
"Table1": {
"id": "http://jsonschema.net/Table1",
"type": "object",
"properties": {
"Data": {
"id": "http://jsonschema.net/Table1/Data",
"type": "array",
"items": {
"type": "array",
"items": [
{
"id": "http://jsonschema.net/Table1/Data/0/0",
"type": "integer"
},
{
"id": "http://jsonschema.net/Table1/Data/0/1",
"type": "string"
},
{
"id": "http://jsonschema.net/Table1/Data/0/2",
"type": "number"
}
],
"additionalItems": false,
"required": [
"0",
"1",
"2"
]
}
}
},
"required": [
"Data"
]
}
}
}
此架构适用于所有数据行,但它所需的 属性 不知何故不起作用。尽管我期待所有 3 列数据。它也接受具有 1 或 2 列的行。 如果有人有任何想法。请指正。
[ 101 ], [ 101, "TEST3" ]
也是预期之外的有效数据记录。
JSON schema 有一个新的元组语法,以前建议的解决方案现在可以这样写:
{
"type": "object",
"properties": {
"Data": {
"type": "array",
"items": [
{
"type": "array",
"prefixItems": [
{ "type": "integer" },
{ "type": "string" },
{ "type": "integer" }
],
"minItems": 3,
"items": false
}
]
}
},
"required": [
"Data"
]
}