🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

2回答

2249閲覧

入れ子のJSONから値を取得したい。

aaraki

総合スコア15

JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2019/09/09 04:52

編集2019/09/09 05:18

{"status":"success","errorCode":0,"message":"ReadingUnit listing.","readingUnits":[{"id":517541,"name":"20190909134842","status":6,"csvFileName":"before.csv","docsetId":16326,"documentId":122855,"documentName":"伝票2-画像加工","createdAt":"2019-09-09 13:48:43.0"}]}
から
"status"を取得したい。
json.loadsを行い、get('readingUnits')を行うと、readingUnitsの値は取れるが、続けてget('status')とすると、'list' object has no attribute 'get'のエラーが出る。
再度、dumpsでJSONに戻し、loadsからget('status')にしても同じ'list' object has no attribute 'get'のエラーが出る。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

うむ、入れ子の中に入れ子とかでなくて良かった。
listとdictを使っているなら、for分で見つけるのが早いですね...

Python

1fields = {"status":"success","errorCode":0,"message":"ReadingUnit listing.","readingUnits":[{"id":517541,"name":"20190909134842","status":6,"csvFileName":"before.csv","docsetId":16326,"documentId":122855,"documentName":"伝票2-画像加工","createdAt":"2019-09-09 13:48:43.0"}]} 2 3statuses = [] 4if 'readingUnits' in fields: 5 readingUnits = fields[readingUnits] 6 7 for readingUnit in readingUnits: 8  if not 'status' in readingUnit: continue 9 statuses.append(readingUnit['status'])

投稿2019/09/09 05:24

編集2019/09/09 05:25
stdio

総合スコア3307

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

aaraki

2019/09/09 06:01

値がとれました。ご回答ありがとうございました。
guest

0

普通にやれば

javascript

1var data={"status":"success","errorCode":0,"message":"ReadingUnit listing.","readingUnits":[{"id":517541,"name":"20190909134842","status":6,"csvFileName":"before.csv","docsetId":16326,"documentId":122855,"documentName":"伝票2-画像加工","createdAt":"2019-09-09 13:48:43.0"}]}; 2console.log(data.readingUnits[0].status);

json.loadsを行い、

がよくわからないですが、非同期処理で読み込み完了しないととれないなら
Promise的なアプローチが必要です。

投稿2019/09/09 04:58

yambejp

総合スコア116661

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

aaraki

2019/09/09 05:06

すみません。java scriptsではなく、pythonのなですが。
yambejp

2019/09/09 05:14 編集

あー(汗)、失礼しました。 pythonタグ追加しておくと良いと思います
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問