JSONがありますVBAで解析しようとしています。私は「オファー」の配列を正常に解析しました。 "オファー"の配列内には、別の配列 "価格" "USD"があります。VBAとJSONを使用したネストされた配列の解析
問題はすべての「オファー」オブジェクトに「米ドル」の配列があるわけではありません。私はテーブル/シートを作ることができるオブジェクトを作成しようとしていますが、オブジェクトをデバッグモードで印刷することさえできません。 Dict OfferDetailsに「USD」オブジェクトが含まれているわけではないため、この機能は動作しますが失敗します。
私がしたいのは、文字列を印刷することができ、「USD」オブジェクトが見つからない場合はスキップし、「USD」を持つものだけを印刷することです。 IsMissing(コード内)を試しましたが、欠落している "USD"オブジェクトにヒットしたときに失敗します。
「USD」の値を使ってこの文字列をどのように取得できますか? 「USD」は配列であり、いくつかのオブジェクトが含まれていますが、どちらに対処するかわかりません。理想的には、私が "オファー"を行ったのと同じ方法で "USD"を解析したいと思います。私はVBAがあまり良くないので、完全に失われています
これは、有効なWeb JSONを持つ作業スクリプトです。
あなたが辞書のExists
メソッドを使用したい
Sub getJSONEP_lib_working()
'Need the JsonConverter found here https://github.com/VBA-tools/VBA-JSON
'Need the Microsoft Scripting Runtime
Dim Parsed As Dictionary
Dim Item As Dictionary
Dim OfferDetails As Dictionary
Dim Price As Dictionary
Dim USD As Dictionary
URL = "http://wraymac.com/JSON/example1.json"
url2 = "[{" & """mpn""" & ":" & """41202""" & "}]"
Set MyRequest = CreateObject("WinHttp.WinHttpRequest.5.1")
MyRequest.Open "GET", URL
MyRequest.Send
JsonString = MyRequest.ResponseText
Dim json As Object
Set json = JsonConverter.ParseJson(JsonString)
Set Parsed = JsonConverter.ParseJson(MyRequest.ResponseText)
For Each Item In Parsed("results")(1)("items")
For Each OfferDetails In Item("offers")
'I tried this it doesn't work, it fails when it finds a non existent "USD"
If Not IsMissing(OfferDetails("prices")("USD")(1)(1)) Then
Debug.Print OfferDetails("prices")("USD")(1)(1)
Else
Debug.Print "Missing"
End If
x = Item("mpn") & " " & "sku" & " - " & OfferDetails("sku") & "," & "UID" & " - " & OfferDetails("seller")("uid") & " " & OfferDetails("moq") & "packaging" & " = " & OfferDetails("packaging") & " " & OfferDetails("seller")("name") & " " & Item("manufacturer")("name")
Debug.Print x
'This works but fails because not every Dict OfferDetails contains the "USD" object
'x = Item("mpn") & " " & "sku" & " - " & OfferDetails("sku") & "," & "UID" & " - " & OfferDetails("seller")("uid") & " " & OfferDetails("moq") & "packaging" & " = " & OfferDetails("packaging") & " " & OfferDetails("seller")("name") & " " & Item("manufacturer")("name")& " "&OfferDetails("prices")("USD")(1)(1)
Next OfferDetails
Next
End Sub
返される実際のJSON文字列を教えてください。 –
私はメッセージに投稿しなかった理由は非常に長いです。だから、ここでそれを得ることができます... http://wraymac.com/JSON/example1.json "http://wraymac.com/JSON/example1.json" それが動作しない場合は、私はそれを投稿することができます – Wraymac
ここでJSONの書式設定を検討してください... http://jsonprettyprint.com/json-pretty-printer.php –