J'ai un fichier JSON members.jsoncomme ci-dessous.
{
"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"
}
}
]
}
}
Je veux l'analyser en utilisant un bashscript pour obtenir uniquement la liste des champs memberId.
Le résultat attendu est:
memberIds
-----------
0x7b93910446f91928e23e1043dfdf5bcf
0x7b93910446f91928e23e1043dfdf5bcG
J'ai essayé d'ajouter le code bash + python suivant à .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'"]';
}
Et puis appelé:
$ cat members.json | getJsonVal "memberId"
Mais ça jette:
Traceback (most recent call last):
File "<string>", line 1, in <module>
KeyError: 'memberId'
Référence
python, et non bash, c'est ce que vous utilisez pour analyser json. Par exemple, cette erreur est certainement une erreur python, pas une erreur bash.
python, ne signifie pas que son objectif est d'utiliserpython