以下は私のjsonファイルの簡単なリストです。
"slider-client" : {
"properties_attributes" : { },
"properties" : { }
}
},
{
"spark2-hive-site-override" : {
"properties_attributes" : { },
"properties" : {
"hive.metastore.client.connect.retry.delay" : "5",
"hive.server2.enable.doAs" : "false",
"hive.server2.thrift.port" : "10016",
"hive.server2.transport.mode" : "binary",
"hive.metastore.client.socket.timeout" : "1800"
}
}
},
{
"tez-env" : {
"properties_attributes" : { },
"properties" : {
"heap_dump_location" : "/tmp",
"content" : "\n# Tez specific configuration\nexport TEZ_CONF_DIR={{config_dir}}\n\n# Set HADOOP_HOME to point to a specific hadoop install directory\nexport HADOOP_HOME=${HADOOP_HOME:-{{hadoop_home}}}\n\n# The java implementation to use.\nexport JAVA_HOME={{java64_home}}",
"enable_heap_dump" : "false",
"tez_user" : "tez"
}
}
},
次に始まる行だけをキャプチャするにはどうすればよいですか?
"properties" : {
そして終わる
}
予想出力の例
"properties" : { }
"properties" : {
"hive.metastore.client.connect.retry.delay" : "5",
"hive.server2.enable.doAs" : "false",
"hive.server2.thrift.port" : "10016",
"hive.server2.transport.mode" : "binary",
"hive.metastore.client.socket.timeout" : "1800"
}
"properties" : {
"heap_dump_location" : "/tmp",
"content" : "\n# Tez specific configuration\nexport TEZ_CONF_DIR={{config_dir}}\n\n# Set HADOOP_HOME to point to a specific hadoop install directory\nexport HADOOP_HOME=${HADOOP_HOME:-{{hadoop_home}}}\n\n# The java implementation to use.\nexport JAVA_HOME={{java64_home}}",
"enable_heap_dump" : "false",
"tez_user" : "tez"
}
これまで私がやったのはこの構文です。これが最善の方法ですか?
awk '/"properties" : {/,/^[[:blank:]]*}$/' file.json
答え1
有効なJSONになるには、入力をオブジェクトの配列として扱う必要があります。
ジャック解決策:
jq '.[] | to_entries[] | .value | if has("properties") then {"properties": .properties} else empty end' yourfile
出力(修正済み):
{
"properties": {}
}
{
"properties": {
"hive.metastore.client.connect.retry.delay": "5",
"hive.server2.enable.doAs": "false",
"hive.server2.thrift.port": "10016",
"hive.server2.transport.mode": "binary",
"hive.metastore.client.socket.timeout": "1800"
}
}
{
"properties": {
"heap_dump_location": "/tmp",
"content": "\n# Tez specific configuration\nexport TEZ_CONF_DIR={{config_dir}}\n\n# Set HADOOP_HOME to point to a specific hadoop install directory\nexport HADOOP_HOME=${HADOOP_HOME:-{{hadoop_home}}}\n\n# The java implementation to use.\nexport JAVA_HOME={{java64_home}}",
"enable_heap_dump": "false",
"tez_user": "tez"
}
}
答え2
「}」より前の属性をキャプチャするには、次のようにします。
awk '/"properties" : {/,/^[[:blank:]]*}$/' file.json