{/* 此页面由 website/scripts/generate-skill-docs.py 从技能的 SKILL.md 自动生成。请编辑源文件 SKILL.md,而非此页面。 */}

EVM

只读 EVM 客户端:支持 8 条链的钱包、代币、Gas 查询。

技能元数据

来源可选 —— 使用 hermes skills install official/blockchain/evm 安装
路径optional-skills/blockchain/evm
版本1.0.0
作者Mibayy(@Mibayy), youssefea(@youssefea), ethernet8023(@ethernet8023), Hermes Agent
许可证MIT
平台linux, macos, windows
标签EVM, Ethereum, BNB, BSC, Base, Arbitrum, Polygon, Optimism, Avalanche, zkSync, Blockchain, Crypto, Web3, DeFi, NFT, ENS, Whale, Security
相关技能solana

参考:完整 SKILL.md

:::info 以下是 Hermes 在触发此技能时加载的完整技能定义。这是技能激活时代理所看到的指令。 :::

EVM 区块链技能

在 8 条链上查询 EVM 兼容区块链数据及美元定价。 14 个命令:钱包组合、代币信息、交易、活动、Gas 追踪器、 网络状态、价格查询、多链扫描、大户检测、ENS 解析、 授权检查器、合约检查器和交易解码器。

支持 8 条链:Ethereum, BNB Chain (BSC), Base, Arbitrum One, Polygon, Optimism, Avalanche (C-Chain), zkSync Era。

无需 API 密钥。零外部依赖 —— 仅使用 Python 标准库 (urllib, json, argparse, threading)。

取代独立的 base 技能。 之前位于 optional-skills/blockchain/base/ 下的 Base 专属代币(AERO, DEGEN, TOSHI, BRETT, WELL, cbETH, cbBTC, wstETH, rETH)和所有 Base RPC 功能已合并到本技能中。在任何命令后添加 --chain base 即可覆盖 Base。


使用时机

  • 用户查询任何 EVM 链上的钱包余额或组合
  • 用户想同时检查同一钱包在所有链上的情况
  • 用户想通过哈希查看交易详情(或解码其操作)
  • 用户想要 ERC-20 代币元数据、价格、供应量或市值
  • 用户想要地址的近期交易历史
  • 用户想要当前 Gas 价格或跨链费用比较
  • 用户想查找近期区块中的大额大户转账
  • 用户要求解析 ENS 名称(vitalik.eth)或反向查找地址
  • 用户想检查合约是否有危险的代币授权
  • 用户想检查智能合约(代理?ERC-20?ERC-721?字节码大小?)
  • 用户想在交易前比较各链的 Gas 成本

前提条件

仅需 Python 3.8+ 标准库。无需 pip 安装。 定价:CoinGecko 免费 API(速率限制,约 10-30 次请求/分钟)。 ENS:ensideas.com 公共 API。 交易解码:4byte.directory 公共 API。

覆盖 RPC 端点:export EVM_RPC_URL=https://your-rpc.com

辅助脚本路径:~/.hermes/skills/blockchain/evm/scripts/evm_client.py


快速参考

SCRIPT=~/.hermes/skills/blockchain/evm/scripts/evm_client.py

# 网络与价格
python3 $SCRIPT stats                            # Ethereum 状态
python3 $SCRIPT stats --chain arbitrum           # Arbitrum 状态
python3 $SCRIPT compare                          # 全部 8 条链的 Gas + 价格

# 钱包
python3 $SCRIPT wallet 0xd8dA...96045            # 组合(ETH + ERC-20)
python3 $SCRIPT wallet 0xd8dA...96045 --chain bsc
python3 $SCRIPT multichain 0xd8dA...96045        # 同一钱包在所有链上

# 代币与价格
python3 $SCRIPT price ETH
python3 $SCRIPT price 0xdAC1...1ec7              # 按合约地址
python3 $SCRIPT token 0xdAC1...1ec7              # ERC-20 元数据 + 市值

# 交易
python3 $SCRIPT tx 0x5c50...f060                 # 交易详情
python3 $SCRIPT decode 0x5c50...f060             # 解码输入数据(4byte.directory)
python3 $SCRIPT activity 0xd8dA...96045          # 近期交易

# Gas
python3 $SCRIPT gas                              # Gas 价格 + 成本估算
python3 $SCRIPT gas --chain optimism

# 安全
python3 $SCRIPT allowance 0xd8dA...96045         # 危险的 ERC-20 授权
python3 $SCRIPT contract 0xdAC1...1ec7           # 合约检查(代理?标准?)

# ENS
python3 $SCRIPT ens vitalik.eth                  # 名称 -> 地址 + 资料
python3 $SCRIPT ens 0xd8dA...96045               # 地址 -> ENS 名称

# 大户检测
python3 $SCRIPT whale                            # 大额转账(最近 20 个区块,>1 万美元)
python3 $SCRIPT whale --blocks 50 --min-usd 100000 --chain arbitrum

操作步骤

0. 安装检查

python3 --version   # 需要 3.8+
python3 ~/.hermes/skills/blockchain/evm/scripts/evm_client.py stats

1. 钱包组合

原生币余额 + 已知 ERC-20 代币,按美元价值排序。

python3 $SCRIPT wallet 0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045
python3 $SCRIPT wallet 0xd8dA... --chain bsc --no-prices   # 更快

2. 多链扫描

使用线程同时扫描全部 8 条链上的同一地址。

python3 $SCRIPT multichain 0xd8dA6BF26964aF9D7eEd9e03E53415D37aA96045

输出:每条链的原生币余额 + 代币持仓 + 总价值(美元)。

3. 比较(Gas + 价格)

并行查询全部 8 条链。显示最便宜/最贵的链。

python3 $SCRIPT compare

4. 交易详情与解码

python3 $SCRIPT tx 0x5c504ed432cb51138bcf09aa5e8a410dd4a1e204ef84bfed1be16dfba1b22060
python3 $SCRIPT decode 0x5c504ed...   # 显示人类可读的函数签名

解码使用 4byte.directory 将 0xa9059cbb 转换为 transfer(address,uint256)。

5. ENS 解析

python3 $SCRIPT ens vitalik.eth          # -> 0xd8dA... + 头像 + 社交链接
python3 $SCRIPT ens 0xd8dA...96045       # -> vitalik.eth

6. 授权检查器(安全)

检查授予已知 DEX/桥接合约的 ERC-20 授权。

python3 $SCRIPT allowance 0xYourWallet

将 UNLIMITED 授权标记为高风险。

7. 合约检查器

python3 $SCRIPT contract 0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48   # USDC(代理)
python3 $SCRIPT contract 0xdAC17F958D2ee523a2206206994597C13D831ec7   # USDT(ERC-20)

检测:代理(EIP-1967/EIP-1167)、ERC-20、ERC-721、ERC-165。显示代理的字节码大小和实现地址。

8. 大户检测

python3 $SCRIPT whale                                    # ETH,最近 20 个区块,>1 万美元
python3 $SCRIPT whale --blocks 50 --min-usd 50000 --chain bsc

9. Gas 追踪器

python3 $SCRIPT gas
python3 $SCRIPT gas --chain polygon

显示 gwei 价格 + 美元成本:转账、ERC-20 转账、授权、兑换、NFT 铸币、NFT 转账。


支持的链

键(Key)名称原生币链 ID
ethereumEthereumETH1
bscBNB ChainBNB56
baseBaseETH8453
arbitrumArbitrum OneETH42161
polygonPolygonPOL137
optimismOptimismETH10
avalancheAvalanche CAVAX43114
zksynczkSync EraETH324

注意事项

  • CoinGecko 免费层:约 10-30 次请求/分钟。使用 --no-prices 加快钱包扫描速度。
  • 公共 RPC 可能限制频率。生产环境中设置 EVM_RPC_URL 为私有端点。
  • walletallowance 仅检查已知代币列表(每条链约 30 种代币)。如需完整代币发现,请使用区块浏览器。
  • activity 仅扫描近期区块(最多 200 个)。如需完整历史,请使用 Etherscan API。
  • multichain 运行 8 个并行线程 —— 可能触发公共 RPC 的速率限制。
  • ENS 解析依赖单个公共端点(ensideas.com / ens.vitalik.ca),无备用方案。如果该端点不可用,ens 将失败 —— 稍后重试或使用区块浏览器。
  • 交易解码依赖单个公共端点(4byte.directory),无备用方案。其数据库中不存在的选择器显示为 unknown
  • L2 Gas 估算仅限 L2 执行成本。 在 Base, Arbitrum, Optimism 和 zkSync 等 Rollup 上,实际交易成本还包括取决于 calldata 大小和当前 L1 Gas 价格的 L1 数据发布费。gas 命令不估算该 L1 部分。对于 Base,请参阅网络的 L1 费用预言机(合约 0x420000000000000000000000000000000000000F)。
  • 地址/交易哈希输入会验证 0x 前缀 + 正确长度 + 十六进制,但不强制 EIP-55 校验和大写(RPC 端点接受任何大小写的十六进制)。

验证

# 应打印当前区块、Gas 价格、ETH 价格
python3 ~/.hermes/skills/blockchain/evm/scripts/evm_client.py stats
 
# 应将 vitalik.eth 解析为 0xd8dA...
python3 ~/.hermes/skills/blockchain/evm/scripts/evm_client.py ens vitalik.eth