POST
/
5b8d22690a57f293b3a1ed8758014e35
curl --request POST \
  --url https://nd-000-364-211.p2pify.com/5b8d22690a57f293b3a1ed8758014e35 \
  --header 'Content-Type: application/json' \
  --data '{
  "id": 1,
  "jsonrpc": "2.0",
  "method": "eth_getBlockTransactionCountByHash",
  "params": [
    "0x7ccd0791880035667dfee8244ab96d9c091668859e9e72ded4890e6efde68b25"
  ]
}'
{
  "jsonrpc": "<string>",
  "id": 123,
  "result": "<string>"
}

Arbitrum API method that returns the number of transactions in a block specified by block hash. This information can be useful for analytics purposes.

Get you own node endpoint today

Start for free and get your app to production levels immediately. No credit card required.

You can sign up with your GitHub, X, Google, or Microsoft account.

Parameters

  • hash — the block hash of the requested block

Response

  • quantity — an integer value representing how many transactions are included in the block.

eth_getBlockTransactionCountByHash code examples

const Web3 = require("web3");

const NODE_URL = "CHAINSTACK_NODE_URL";

const web3 = new Web3(NODE_URL);


async function getTransactionsCount(blockHash) {

  const count = await web3.eth.getBlockTransactionCount(blockHash)

  console.log(count);

}


getTransactionsCount('0x0cf9ebbbc3ecf05ac1f79095ee5699602b9b010278628aa58ecf6e058a41562a')

Use case

eth_getBlockTransactionCountByHash is a useful tool for analyzing transaction volume on the Arbitrum blockchain. On average, a new block is generated on the Arbitrum mainnet every 0.3 seconds, resulting in approximately 12,000 blocks per hour. Using the web3.js library, one can inspect the past 12,000 blocks starting from the latest block, retrieve the hash of each block, and use eth_getBlockTransactionCountByHash to find the number of transactions in each block.

index.js
const Web3 = require("web3");

const NODE_URL = "CHAINSTACK_NODE_URL";

const web3 = new Web3(NODE_URL);


async function retrieveTransactionsCount() {

  // Get the current block number

  const currentBlockNumber = await web3.eth.getBlockNumber();


  // Calculate the block number from one hour ago

  const oneHourAgoBlockNumber = currentBlockNumber - 12000; // 12000 blocks/hr on average on the Arbitrum mainnet

  
  // Initialize a variable to store the total number of transactions

  let totalTransactionCount = 0;


  // Loop through all blocks from the current block number to the block number from one hour ago

  for (let block = currentBlockNumber; block > oneHourAgoBlockNumber; block--) {


    // Get the hash of each block

    const getBlockHash = await web3.eth.getBlock(block, false);

    const blockHash = getBlockHash.hash


    // Get the number of transactions in this block using each hash

    const transactionCount = await web3.eth.getBlockTransactionCount(blockHash);


    // Add the number of transactions in this block to the total

    totalTransactionCount += transactionCount;


    console.log(`Block #${block} has ${transactionCount} transactions.`);

  }


  console.log(`The total number of transactions in the previous hour is: ${totalTransactionCount}`);

}



retrieveTransactionsCount();

This example connects to an Arbitrum node using the web3.js library. The retrieveTransactionsCount function gets the current block number, calculates the block number from one hour ago, and uses a for loop to iterate through all blocks in that range.

The function then retrieves the hash of each block and the number of transactions in each block and adds it to a total transaction count. The final result, the total number of transactions in the previous hour, is logged to the console.

This is a good example of how you can combine different methods.

Body

application/json
id
integer
default:1
jsonrpc
string
default:2.0
method
string
default:eth_getBlockTransactionCountByHash
params
string[]

The block hash identifier.

Response

200 - application/json
The block information
jsonrpc
string
id
integer
result
string