需要在windows上实现一个bat脚本解析json,将json转换为自己想要的key-value样式,来压缩复杂json。

此外为了保证脚本的灵活性,我在json中添加一个bat节点,用于指明需要抽取该json中的哪些节点进行压缩( 1>某些节点信息没有用,因此不用提取;2>节点所对应的key太长了,因此可以用新的key替代老的key来压缩)

二、json例子

json例子如下 a.json

"light": { "bat": { "value": [ "/.light.category.value/category/", "/.light.dmod.value/dmod/", "/.light.color.r.pin.value/rpin/", "/.light.color.r.lv.value/rlv/", "/.light.color.g.pin.value/gpin/", "/.light.color.g.lv.value/glv/", "/.light.color.b.pin.value/bpin/", "/.light.color.b.lv.value/blv/", "/.light.color.cct_l.pin.value/cct_lpin/", "/.light.color.cct_l.lv.value/cct_llv/", "/.light.color.cct_wc.pin.value/cct_wcpin/", "/.light.color.cct_wc.lv.value/cct_wclv/", "/.light.other_lamp.min_lum.value/min_lum/", "/.light.other_lamp.pwmhz.value/pwmhz/"] "cmod": { "value": "rgbwc" "dmod": { "value": "pwm" "color": { "cct_l": { "pin": { "value": 6 "lv": { "value": true "r": { "pin": { "value": 7 "lv": { "value": true "b": { "pin": { "value": 4 "lv": { "value": true "g": { "pin": { "value": 3 "lv": { "value": true "cct_wc": { "pin": { "value": 5 "lv": { "value": true "other_lamp": { "min_lum": { "value": 10 "pwmhz": { "value": 8000 "ickind": { "value": "tlsr8266" "category": { "value": "0501"

三、bat脚本

解析脚本为 a.bat

该脚本首先从a.json中读取bat的值:
1)这里不直接用.light.bat.value的原因是:light关键词可能是其他值,因此需要采用特殊的写法进行模糊匹配;

2)这里使用bat的FOR的用法,比较复杂,其中:delims=/ tokens=2,3的意思是每次执行jq-win64.exe...的命令返回的每一行,通过/分割为多列,取其中的第2、3列赋值给%%I和%%J;

3)mzip是读取文件的多行,并输出一行字符串;

@echo off
setlocal enabledelayedexpansion
set out_file=config.bin
echo {> %out_file%
for /F "delims=/ tokens=2,3" %%I in ('jq-win64.exe ".[] | .bat.value[]" a.json') do (
	echo %%I
	echo %%J
	call:fjq %%I %%J
echo }>> %out_file%
cat %out_file%
call:mzip
cat %out_file%
pause
goto:eof
echo %2:>> %out_file%
jq-win64.exe %1 a.json>> %out_file%
echo ,>> %out_file%
goto:eof
:mzip
set "Str="
for /f "delims=" %%b in (%out_file%) do (
    set "Str=!Str!%%~b"
>tmp$ echo !Str!
move /y tmp$ "%out_file%" >nul
goto:eof

本文主要运用了:windows的bat脚本技术、jq解析json技术、动态脚本技术。

  • BAT FOR循环的用法
  • BAT 函数的用法
  • BAT 读取文件的多行,合并为一行字符串输出
  • jq对json的模糊匹配
  • @beautifulzzzz
    智能硬件、物联网,热爱技术,关注产品
    博客:http://blog.beautifulzzzz.com
    园友交流群:414948975