You need to enable JavaScript to run this app.
最新活动
大模型
产品
解决方案
定价
生态与合作
支持与服务
开发者
了解我们

使用CCXT调用Binance API的fetch_ohlcv()接口时传入since参数触发BadRequest错误求助

问题原因分析与解决方案

从你提供的错误信息参数'startTime'中存在非法字符;合法格式为'^[0-9]{1,20}$',以及请求URL里的startTime=1589817600.0,可以明确问题所在:

核心问题

你传入的since参数是带小数点的浮点数时间戳,而Binance API要求startTime必须是纯整数格式的毫秒级时间戳,不允许出现小数部分。

你的代码里,datetime.timestamp(startDate)返回的是秒级的浮点数时间戳,直接传给fetch_ohlcvsince参数后,CCXT会把这个浮点数原样拼到请求URL里,导致Binance API拒绝请求。另外,CCXT的fetch_ohlcv方法的since参数规范是毫秒级整数时间戳,这也是跨交易所统一的标准格式,你之前的时间戳精度(秒级)也不符合要求。

修正方案

只需要把秒级浮点数时间戳转换为毫秒级整数时间戳即可,修改代码中处理startDate的最后一步:

修正后的代码片段

symbol = 'ETH/BTC'
timeframe = '1d'
limit = 50 #Default best for binance
startDate = "2020-05-19"
startDate = datetime.strptime(startDate, "%Y-%m-%d")
# 关键修改:转成毫秒级整数时间戳
startDate = int(datetime.timestamp(startDate) * 1000)
config = {
    'rateLimit': 10000,
    'apiKey': apiKey,
    'secret': secretKey
}
exchange = ccxt.binance(config)
# 现在传入的since是整数格式的毫秒时间戳
exchange.fetch_ohlcv(symbol, timeframe, since=startDate, limit=limit)

额外说明

  • 为什么不传since时能正常运行?因为当你不指定since参数时,Binance API会默认返回最近的K线数据,不需要验证时间戳格式。
  • CCXT的时间戳参数统一遵循毫秒级整数规范,其他交易所的API也大多遵循这个标准,所以养成转换时间戳的习惯可以避免类似问题。

内容的提问来源于stack exchange,提问作者mkmkmkmk

火山引擎 最新活动