Async Usage
import asyncio
from defistream import AsyncDeFiStream
async def main():
async with AsyncDeFiStream() as client:
df = await (
client.erc20.transfers("USDT")
.network("ETH")
.block_range(21000000, 21010000)
.as_df()
)
print(f"Found {len(df)} transfers")
asyncio.run(main()) Calculate Query Cost
Preview how many blocks a query will cost before executing it. No quota is deducted.
# Build a query as usual, then call calculate_cost() instead of as_df()
cost = (
client.erc20.transfers("USDT")
.network("ETH")
.block_range(21000000, 21010000)
.calculate_cost()
)
print(cost.cost) # 10000
print(cost.quota_remaining) # 500000
print(cost.quota_remaining_after) # 490000
# Also works on aggregate queries
cost = (
client.erc20.transfers("USDT")
.network("ETH")
.block_range(21000000, 21100000)
.aggregate(group_by="time", period="1h")
.calculate_cost()
)