data:image/s3,"s3://crabby-images/8b4aa/8b4aa999d801fa45f105bd7a2507596a0106b08c" alt=""
VBAで
・JSONをパース
できます!
data:image/s3,"s3://crabby-images/8b4aa/8b4aa999d801fa45f105bd7a2507596a0106b08c" alt=""
GitHubで公開されている
・VBA-JSON
を使用してパースします!
VBA-JSON(JsonConverter.bas)の取得
以下のURLにアクセスする。
「Code」-「Download ZIP」をクリックして「VBA-JSON-master.zip」をダウンロードする。
data:image/s3,"s3://crabby-images/c73a3/c73a310810dcf361373c60946fe9b7a280530a5b" alt="「VBA-JSON-master.zip」をダウンロード"
「VBA-JSON-master.zip」を展開して、展開後のフォルダの中にある「JsonConverter.bas」をVBEにドロップ & ドラッグする。
data:image/s3,"s3://crabby-images/d20d6/d20d638eb7a6c6d56d058cd46658f78897367a52" alt="「JsonConverter.bas」をVBEにドロップ & ドラッグする"
data:image/s3,"s3://crabby-images/08c8c/08c8ccf278a9906016a277ce86ac5908f008b682" alt="ドロップ & ドラッグした結果"
VBA-JSON(JsonConverter.bas)の微修正
「JsonConverter.bas」の以下の2行を修正します。
※「コメントアウト」と「追記」をします。
'Private Function json_ParseObject(json_String As String, ByRef json_Index As Long) As Dictionary ←コメントアウト
Private Function json_ParseObject(json_String As String, ByRef json_Index As Long) As Scripting.Dictionary ←追記
'Set json_ParseObject = New Dictionary ←コメントアウト
Set json_ParseObject = New Scripting.Dictionary ←追記
参照設定に「Selenium Type Library」を追加している場合、本手順を実施しないと以下のエラーが発生します。
実行時エラー ‘0’:
KyeNotFoundError
Dictionary key not found:title
data:image/s3,"s3://crabby-images/d0571/d057180afa4371bc6a27739effef65ecfb739682" alt="エラーメッセージ"
参照設定の追加
参照設定に「Microsoft Scripting Runtime」を追加します。
※「VBA-JSON(JsonConverter.bas)」内で「Microsoft Scripting Runtime」内のオブジェクトを使用しているため。
VBEの「ツール」-「参照設定」をクリックして、「Microsoft Scripting Runtime」にチェックを入れ「OK」をクリックします。
data:image/s3,"s3://crabby-images/5450b/5450b5914e74bad7ade08df5d000c8b68114b833" alt="参照設定に「Microsoft Scripting Runtime」を追加"
VBAコード
ここでは例として
・EDINETのWeb APIを使用してJSONデータを取得して
・JSONデータをパースして得られた結果の一部をイミディエイトウィンドウへ出力
します。
Option Explicit
Sub sample()
Dim url As String
Dim http As Object
Dim json As Variant
'メタデータ(=JSON)を取得するEDINETのWeb API
url = "https://disclosure.edinet-fsa.go.jp/api/v1/documents.json?date=2023-04-11&type=1"
'HTTPリクエスト
Set http = CreateObject("WinHttp.WinHttpRequest.5.1")
http.Open "GET", url, False
http.Send
'HTTPレスポンス(=JSON)をパース
Set json = JsonConverter.ParseJson(http.responseText)
'パースした結果をイミディエイトウィンドウへ出力
'┗[metadata]-[title]
'┗[metadata]-[parameter]-[date]
'┗[metadata]-[status]
Debug.Print json("metadata")("title")
Debug.Print json("metadata")("parameter")("date")
Debug.Print json("metadata")("status")
'後片付け
Set http = Nothing
End Sub
実行結果
JSONをパースできました。
※JSONデータをパースして得られた結果の一部をイミディエイトウィンドウへ出力できました。
data:image/s3,"s3://crabby-images/c31d8/c31d8aaf4e738f77862ca9b3987d0169ef730211" alt="実行結果"
参考①
上記で使用した以下の詳細は、公式サイトをご確認ください。
●「winhttprequestPオブジェクト」の「Open」メソッド
●「winhttprequestPオブジェクト」の「Send」メソッド
参考②
EDINETとは「金融商品取引法に基づく有価証券報告書等の開示書類に関する電子開示システム」のことです。
詳細は金融庁のWebサイトをご確認ください。