ฉันมีไฟล์ JSON members.json
ดังต่อไปนี้
{
"took": 670,
"timed_out": false,
"_shards": {
"total": 8,
"successful": 8,
"failed": 0
},
"hits": {
"total": 74,
"max_score": 1,
"hits": [
{
"_index": "2000_270_0",
"_type": "Medical",
"_id": "02:17447847049147026174478:174159",
"_score": 1,
"_source": {
"memberId": "0x7b93910446f91928e23e1043dfdf5bcf",
"memberFirstName": "Uri",
"memberMiddleName": "Prayag",
"memberLastName": "Dubofsky"
}
},
{
"_index": "2000_270_0",
"_type": "Medical",
"_id": "02:17447847049147026174478:174159",
"_score": 1,
"_source": {
"memberId": "0x7b93910446f91928e23e1043dfdf5bcG",
"memberFirstName": "Uri",
"memberMiddleName": "Prayag",
"memberLastName": "Dubofsky"
}
}
]
}
}
ฉันต้องการที่จะแยกโดยใช้สคริปต์ได้รับเพียงรายชื่อของสนามbash
memberId
ผลลัพธ์ที่คาดหวังคือ:
memberIds
-----------
0x7b93910446f91928e23e1043dfdf5bcf
0x7b93910446f91928e23e1043dfdf5bcG
ฉันพยายามเพิ่ม bash + python code ต่อไปนี้.bashrc
:
function getJsonVal() {
if [ \( $# -ne 1 \) -o \( -t 0 \) ]; then
echo "Usage: getJsonVal 'key' < /tmp/file";
echo " -- or -- ";
echo " cat /tmp/input | getJsonVal 'key'";
return;
fi;
cat | python -c 'import json,sys;obj=json.load(sys.stdin);print obj["'$1'"]';
}
แล้วเรียกว่า:
$ cat members.json | getJsonVal "memberId"
แต่มันจะพ่น:
Traceback (most recent call last):
File "<string>", line 1, in <module>
KeyError: 'memberId'
การอ้างอิง
python
และไม่ใช่bash
สิ่งที่คุณใช้ในการแยกวิเคราะห์ json เช่นข้อผิดพลาดนั้นเป็นข้อผิดพลาดของ python ไม่ใช่ข้อผิดพลาด bash
python
ไม่ได้หมายความว่าเป้าหมายของเขาคือการใช้python