GoogleスプレッドシートからGASでEtherScanのAPIをたたいて、トランザクションの一覧を取得してみました。
EtherScanのユーザー登録+API key取得
まずは、EtherScanのサイトでアカウントを作成します。
data:image/s3,"s3://crabby-images/80c79/80c79155643ddab016487579064e2e9e5ce520db" alt=""
Ethereum (ETH) Blockchain Explorer
Etherscan allows you to explore and search the Ethereum blockchain for transactions, addresses, tokens, prices and other activities taking place on Ethereum (ET...
アカウント作成が完了したら、API Keyを取得します。
data:image/s3,"s3://crabby-images/29adb/29adb3f0d9592656ce26260269b0697fb2625567" alt=""
data:image/s3,"s3://crabby-images/1b37a/1b37a4d3b5f5c02f67abf9a05b2708818a5b7f72" alt=""
data:image/s3,"s3://crabby-images/3bca0/3bca077e7ca82bc4b08401e85037d708c5bcdecf" alt=""
data:image/s3,"s3://crabby-images/37fd6/37fd6777505b0aabcf9e7f2683be211375e788ce" alt=""
スプレッドシートとGoogle Apps Scriptを作成
適当にスプレッドシートを作成し、ツール > スクリプトエディタでスクリプトを作成。
function getEtherTransaction() { // 定数設定 const sheet = SpreadsheetApp.getActiveSheet() const apiKey = "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX" // EtherScanで取得したAPI key const address = "XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX" // ウォレットのアドレス // EtherScanからデータ取得 const response = UrlFetchApp.fetch(`https://api.etherscan.io/api?module=account&action=txlist&address=${address}&startblock=0&endblock=99999999&sort=asc&apikey=${apiKey}`) const json = JSON.parse(response) // シート貼り付け用の配列 const data = [] // key取得 data.push( Object.keys(json.result[0]) ) // value取得 for ( const item of json.result ){ data.push(Object.values(item) ) } // シートに貼り付け sheet.getRange(1,1,data.length,data[0].length).setValues(data) }
実行してみる
早速実行してみました。
data:image/s3,"s3://crabby-images/e4cd0/e4cd08721b54275aa036b5bea095d22d653bd454" alt=""
意外と簡単にデータが取得できました。
が、timeStampとかvalueとか、諸々処理したほうが良さそうです。
コメント