本文へスキップ
このページは英語からの機械翻訳を使用しており、誤りや不明瞭な表現が含まれている可能性があります。最も正確な情報については、オリジナルの英語版をご覧ください。頻繁な更新のため、一部のコンテンツはオリジナルの英語になっている可能性があります。Crowdinでの取り組みに参加して、このページの翻訳改善にご協力ください。 (Crowdin translation page, Contributing guide)

読む

スマートコントラクトの関数は、RPC API「Call」を使って呼び出すことができる。 ここで呼び出せるのは、コントラクトのステートを変更しないビュー関数に限られる。

web3をkaia web3に拡張するために、web3py_extからextendをインポートする。

指定されたkairosテストネットURLでWeb3インスタンスを作成する

また、プロバイダーのURLをkairosからquicknodeに変更することもできます。

契約アドレスabi**で契約インスタンスを作成する。

デプロイチュートリアルでデプロイしたコントラクトアドレスを設定します(カウンターコントラクト)。 デプロイされたTXの領収書に住所が記載されています。

契約アビを設定する。 remixまたはsolcコンパイラでコンパイル後、ABIを取得できます。

ビュー関数を呼び出す。 これはブロックチェーンノードへの単なるRPC呼び出しであり、トランザクションではありません

smart_contract_interaction.py

from web3py_ext import extend
from web3 import Web3
w3 = Web3(Web3.HTTPProvider(
'https://public-en-kairos.node.kaia.io'
))
def contract_interaction():
c = w3.eth.contract(
address="0x95Be48607498109030592C08aDC9577c7C2dD505",
abi = [{"inputs":[{"internalType":"uint256","name":"initNumber","type":"uint256"}],"stateMutability":"nonpayable","type":"constructor"},{"anonymous":False,"inputs":[{"indexed":False,"internalType":"uint256","name":"number","type":"uint256"}],"name":"SetNumber","type":"event"},{"inputs":[],"name":"increment","outputs":[],"stateMutability":"nonpayable","type":"function"},{"inputs":[],"name":"number","outputs":[{"internalType":"uint256","name":"","type":"uint256"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"uint256","name":"newNumber","type":"uint256"}],"name":"setNumber","outputs":[],"stateMutability":"nonpayable","type":"function"}]
)
# call view function
print('\nnumber : ', c.functions.number().call())
contract_interaction()

output

❯ smart_contract_interaction.py
番号 : 294

ページを改善してください。