Вот простое решение на основе jtc
утилиты Unix:
bash $ jtc -w'<.*>D:' -eu echo '"{}"' \; file.json
{
"amount": "1000",
"country": "GB",
"customer": "user",
"id": "1",
"plate": "BMT-216-A",
"pndNumber": "20000",
"zoneNumber": "4"
}
bash $
если вы хотите применить изменения прямо к файлу json, используйте -f
переключатель, например так:
bash $ jtc -f -w'<.*>D:' -eu echo '"{}"' \; file.json
Предложенное решение будет корректно работать с произвольными структурированными jsons, например:
bash $ jtc -w'<.*>D:' -eu echo '"{}"' \; file.json
{
"amount": "1000",
"country": "GB",
"customer": "user",
"id": "1",
"plate": "BMT-216-A",
"pndNumber": "20000",
"sub": {
"subvalue": "123"
},
"zoneNumber": "4"
}
bash $
- если вам нравится заключать в кавычки нулевые значения, просто добавьте прогулочный путь
-w'<>n:'
- если вы хотите процитировать булевы значения, добавьте прогулочный путь
-w'<any>b:'
Кроме того, обратная задача (отменить кавычки для всех чисел) легко достигается аналогичным образом: скажем, file.json
уже "заключена в кавычки", чтобы снять все кавычки:
bash $ jtc -w'<^\d+$>R:' -eu echo {-} \; file.json
{
"amount": 1000,
"country": "GB",
"customer": "user",
"id": 1,
"plate": "BMT-216-A",
"pndNumber": 20000,
"zoneNumber": 4
}
bash $
ОБНОВЛЕНИЕ : последняя версия jtc
реализует теперь шаблоны и пространства имен. При этом не требуется вызова внешней оболочки:
bash $ jtc -w'<.*>D:' -u'<.*>D:<val>v' -T'"{val}"' file.json
{
"amount": "1000",
"country": "GB",
"customer": "user",
"id": "1",
"plate": "BMT-216-A",
"pndNumber": "20000",
"zoneNumber": "4"
}
jtc
руководство пользователя: https://github.com/ldn-softdev/jtc/blob/master/User%20Guide.md
{"a":{"b":1},"b":null}
на{ "a": "{\"b\":1}", "b": "null" }