Skip to main content
版本: 0.11

数据集成

简介

在 KCL 中,不仅可以将 KCL 编写的配置代码编译输出为 YAML 格式的数据,还可以将 JSON/YAML 等数据直接嵌入到 KCL 语言当中。

使用 KCL 进行数据集成

0. 先决条件

1. 获得示例

git clone https://github.com/kcl-lang/kcl-lang.io.git/
cd ./kcl-lang.io/examples/data-integration

2. YAML 集成

我们可以运行以下命令来显示 KCL YAML 集成配置。

cat yaml.k
import yaml

schema Server:
ports: [int]

server: Server = yaml.decode("""\
ports:
- 80
- 8080
""")
server_yaml = yaml.encode({
ports = [80, 8080]
})

在上述代码中,我们通过 KCL 内置的 yaml 模块以及其中的 yaml.decode 直接完成 YAML 数据的集成,并且使用 Server schema 对集成的 YAML 数据直接进行校验。此外,我们可以使用 yaml.encode 完成 YAML 数据的序列化。

我们通过如下命令可以获得配置输出:

kcl yaml.k

输出为

server:
ports:
- 80
- 8080
server_yaml: |
ports:
- 80
- 8080

此外,KCL 支持使用 file 模块从文件中读取数据,您可以从文件中读取 YAML 数据并进行进一步的操作与修改。

import file
import yaml

deployment = yaml.decode(file.read("deployment.yaml")) | {
metadata.name = "override_name"
}

3. JSON 集成

同样的,对于 JSON 数据,我们可以使用 json.encodejson.decode 函数以同样的方式进行数据集成。

我们可以运行以下命令来显示 KCL JSON 集成配置。

cat json.k
import json

schema Server:
ports: [int]

server: Server = json.decode('{"ports": [80, 8080]}')
server_json = json.encode({
ports = [80, 8080]
})

执行命令输出为:

kcl json.k
server:
ports:
- 80
- 8080
server_json: '{"ports": [80, 8080]}'

小结

本文介绍了如何在 KCL 中进行数据集成,使用 KCL 内置的 yaml 和 json 包将 YAML 和 JSON 数据直接集成到 KCL 语言中,并使用相应的解码和编码功能对其进行验证和序列化。