首页 > 其他分享 >如何使用CCXT交易数字货币现货

如何使用CCXT交易数字货币现货

时间:2023-07-19 21:23:29浏览次数:46  
标签:CCXT 数字 exchange symbol ccxt API 现货 交易所

更多精彩内容,欢迎关注公众号:数量技术宅,也可添加技术宅个人微信号:sljsz01,与我交流。

数字货币现货标准化接口

数字货币市场与股票、期货市场最大的不同点在于数字货币主流交易所数量很多。举个例子,如果我们需要交易螺纹钢期货(RB),我们只能选择上海期货交易所。然而,如果我们想交易比特币,有币安、欧易、火币、Coinbase、Bitmex、Bitfinix、FTX等等很多主流的数字货币交易所可供选择。

对于量化交易或程序交易者来说,数字货币市场最大的痛点在于,每一个数字货币交易所都有自己的API接口,尽管接口大致范式相似,但是细节上有很多不同点,如果交易10家交易所,我们就需要搞懂10个不同的API,并将其接入,这无疑是一件费时费力的事。那么,是否有一个统一的、通用的、标准化的接口,能让我们轻松接入几乎所有主流币圈交易所?

这时候,就需要引入一个 数字货币三方接口CCXT了,这个接口是一个支持多家主流数字货币交易所的标准化接口,CCXT在底层封装了支持主流交易所的现货API,并在表层用让用户可以同样的外接接口访问不同交易所的API,为我们开发多市场尤其是跨市场策略提供了极大的便利。

CCXT接口除了支持几乎所有主流交易所现货API的统一封装外,还支持部分交易所合约(如币安合约)交易的隐式封装,关于隐式封装的使用,大家可以参考我们的历史文章:(链接)。本文将重点介绍CCXT现货API的使用。

如何安装CCXT,如何查询帮助文档

安装CCXT

对于Python语言,安装CCXT与其他Python三分库的方式是一样的。使用语句pip install ccxt即可安装。

安装完成后,我们可以尝试使用import ccxt导入CCXT库,如果运行该语句没有报错,说明CCXT已经成功导入

CCXT Manual (帮助文档)

CCXT提供了详细的帮助文档,可以通过网址https://docs.ccxt.com/en/latest/manual.html#markets进行访问。帮助文档的侧边栏提供了不同API接口的分类,包括MarketAPI、Implicit API、Unified API、Public API、Private API等类别,方便用户根据自己的需要进行分类查询。

而对于每个API,CCXT不仅给出了调用函数名、参数、示例的说明,也给出了调用后的返回结构数据。图例是Market分类中Currency Structure的返回结构。

CCXT初始化

介绍完CCXT的安装以及如何查找帮助文档,接下来我们开始使用CCXT。CCXT的初始化可以分为三步,其中第三步可选,前两步必做。

第一步,加载ccxt模块

第二步,初始化,调用ccxt.交易所名称,其中交易所名称可以替换为任何想要的交易所

第三步,获取初始化交易所的交易市场及交易货币对(测试交易所是否加载成功)

# 加载ccxt模块
import ccxt
print(ccxt.exchanges)

# market API
exchange = ccxt.binance()
markets = exchange.load_markets()
print(exchange.fetch_markets())
print(exchange.fetchCurrencies())

运行结果:先打印CCXT支持的所有交易所,可以看到,CCXT支持的交易所数量很多,足以满足大部分量化交易员的日常开发。

然后我们以币安交易所现货为例,获取币安交易所现货支持的市场和币对。通过markets变量的总数我们可以看到,币安交易所的现货币对一共有2098个,并且这些币对的详细交易信息也由CCXT通过dict的数据格式反馈给我们了。

如何调用CCXT行情API

初始化CCXT后,接下来我们再尝试调用CCXT的现货行情API,获取各种各样的行情数据。CCXT帮我们封装好了从订单簿、ticker、到成交、K线的几乎所有能够在策略中用得到的行情数据,都可以用标准方法,一键调用。

我们通过一个循环,实现对所有币种行情数据调用查询,包括:

获取订单簿、获取公开成交数据、获取ticker数据、获取k线数据

# quote API
# 设置间隔2秒
delay = 0.5
# 对币安所有交易的数字货币对循环
for symbol in exchange.markets:
   # 打印当前数字货币对
   print(symbol)
   # 获取该数字货币对当前的订单簿,并打印
   print(exchange.fetch_order_book(symbol, 10))
   time.sleep(delay)
   print(exchange.fetch_trades(symbol, limit=5))
   time.sleep(delay)
   print(exchange.fetch_ticker(symbol))
   time.sleep(delay)
   print(exchange.fetch_ohlcv(symbol, '1d'))
   time.sleep(delay)

我们再以BTCUSDT为例,来看获取后返回的数据结构。

订单簿(以获取10档盘口数据为例)

公开成交数据

ticker数据

k线数据(以日线为例)

如何调用CCXT交易API

在熟悉了行情API后,我们再来尝试使用CCTX的交易API。但使用交易API前必须注意的是,由于行情API是公有API,而交易API是私有API,所以我们必须调用CCXT的方法,把key传入刚才创建的交易所变量,才能实现调用私有API的权限,传入方法如下

api_key = ""  # 币安的api key
secret_key = ""  # 币安的secret key
exchange.apiKey = api_key
exchange.secret = secret_key

然后,我们可以开始执行一系列与私有API相关的操作,包括:

a. 资产查询

b. 订单查询(包括所有、未完成、已完成订单)

c. 成交查询

d. 报单(市价、限价、买报单、卖报单)

e. 撤单

# trade API
# 资产查询
exchange.fetch_balance()
# 订单查询(依次是所有、未完成、已完成订单)
exchange.fetchOrders(symbol)
exchange.fetchOpenOrders(symbol)
exchange.fetchClosedOrders(symbol)
# 成交查询
exchange.fetchMyTrades(symbol)
# 报单(依次是市价、限价、买报单、卖报单)
exchange.create_order(symbol, 'market', 'buy', amount)
exchange.createLimitBuyOrder(symbol, amount, orderprice)
exchange.createLimitSellOrder(symbol, amount, orderprice)
exchange.createMarketBuyOrder(symbol, amount)
exchange.createMarketSellOrder(symbol, amount)
# 撤单
exchange.cancel_order(order_id)

我们来看上述调用查询后的结果

资产查询

订单查询(所有,以symbol = BUSD/USDT为例)

成交查询(以symbol = BUSD/USDT为例)

对于报单、撤单,如果报单撤单成功,返回的信息是报单的order_id或撤单的order_id,如果错误,会返回相应错误代码及错误原因,在此不一一举例,详细可查询CCXT或交易所帮助文档错误代码描述部分。

CCXT获取行情数据并交易的小栗子

最后,将我们刚才学习的CCXT初始化、调用行情API、调用交易API结合起来,就可以完成一个简单的从初始化交易所加载Key,到获取最新行情,再到按照该行情价格下单的一个小栗子。栗子虽小,但它打通了整个CCXT的现货API。

# 加载ccxt模块
import ccxt
# 加载Key
exchange = ccxt.binance()
api_key = ""  # 币安的api key
secret_key = ""  # 币安的secret key
exchange.apiKey = api_key
exchange.secret = secret_key
symbol = 'BTC/USDT'
# 获取最新行情
orderbook = exchange.fetch_order_book(symbol)
orderprice = orderbook['asks'][0][0] if len(orderbook['asks']) > 0 else None
# 按照该行情价格下买单
amount = 1
exchange.createLimitBuyOrder(symbol, amount, orderprice)

值得一提的是,CCXT交易现货方便之处就在于,如果上述代码,我们不交易币安而是交易其他任何一个CCXT支持的现货交易所,我们只需要将exchange = ccxt.binance()语句ccxt.后面的交易所名称,换成其他交易所,而不改变其他任何代码,就能实现不同交易所交易的无缝切换了。CCXT交易多交易所现货的小技能,你Get到了吗

 

 

 

标签:CCXT,数字,exchange,symbol,ccxt,API,现货,交易所
From: https://www.cnblogs.com/sljsz/p/17566779.html

相关文章

  • 【开源项目】智慧化工厂~经典开源项目数字孪生智慧化工厂——开源工程及源码
       大型化工厂工程与源码免费赠送!沈阳某厂,智慧加速,限时独享! 项目介绍智慧化工厂项目:沈阳某大型化工厂引入智慧化工厂方案,实现全面升级,提高生产效率。  数字孪生技术应用:利用数字孪生技术,充分整合数据与场景,完整克隆出化工厂的三维场景,为工厂管理提供全方位支......
  • 数字孪生系统为何需要将GIS系统进行融合?
    数字孪生是一种通过数字模型实时仿真现实世界的技术,而GIS(地理信息系统)则是用于收集、存储、处理和展示地理数据的工具。将数字孪生系统与GIS系统进行融合,可以为各行业带来诸多优势和创新。那么数字孪生系统如何将GIS系统进行融合?这个问题首先需要结合目前的实际情况来分析,我们先要......
  • 用微服务架构推进企业数字化转型升级
    随着数字化转型进入深水区,企业应用程序建设需求急剧增长且变化多端,软件架构经历了单体结构、垂直架构、SOA架构,发展到了现在的微服务架构。单体架构目前应用较多,部署容易,但单体式应用内部包含了所有需要的服务,且各个服务功能模块有很强的耦合性,也就是相互依赖彼此,很难拆分和扩容,......
  • 连续的英文字符和阿拉伯数字不能换行
    原因:这是因为div中,英文字母之间没有空格的话,它会默认认为这是一个英文单词,所以单词就一次输出不换行。解决方法(以IE,chrome,FF为测试浏览器):{word-break:break-all;/*支持IE,chrome,FF不支持*/word-wrap:break-word;/*支持IE,chrome,FF*/}......
  • mysql如何判断是不是数字?
    在MySQL中,可以使用以下方法来判断一个值是否是数字:1.使用内置函数:MySQL内置了一些函数,如ISNUMERIC()、CAST()、CONVERT()等,可以用来判断一个值是否为数字。例如,使用ISNUMERIC()函数判断一个字符串是否是数字,可以执行以下查询: SELECTISNUMERIC('12345');--返回1,表示是数字......
  • 全新数字资产MBA币:独特模式和销毁机制激发市场价值
    近日,一种全新的数字资产—MBA币,引起了市场的广泛关注。MBA币的模式是其核心特点之一,投资者可以在BRAHMA(MBA)去中心化换汇平台上使用MiMi进行挖,从而产出MBA币,这种模式为投资者提供了稳定且可观的回报,吸引了越来越多的投资者加入其中。随着BRAHMA(MBA)平台会员人数的不断增加,对MBA币的需......
  • 【专题】2022年中国制造业数字化转型研究报告PDF合集分享(附原数据表)
    报告链接:http://tecdat.cn/?p=32145原文出处:拓端数据公众号本文中所说的制造业数字化转型,指的是在制造企业的设计、生产、管理、销售及服务的每一个环节中,将新一代信息技术应用到制造企业的设计、生产、管理、销售及服务的每一个环节中,并可以以每一个环节中产生的数据为基础,展开......
  • 数字孪生技术在医疗领域的应用:精准诊断与个性化治疗
    随着科技的不断进步,数字孪生技术正逐渐融入医疗领域,为医学研究、诊断和治疗带来了新的可能性。数字孪生是指将现实世界的实体或过程通过数字化方式呈现出来,以实现仿真、模拟和预测。在医疗领域,数字孪生技术能够模拟人体器官、疾病进程和药物反应等关键信息,为医生和研究人员提供更......
  • RealChar:实时AI数字人
     RealChar——一个全能的开源代码库,先看演示。 谁需要RealChar-您的实时人工智能角色-如果您已经厌倦了文字聊天,想要交谈-如果您想随身携带您的人工智能角色-如果您想进行全面的自定义-如果您是一名工程师,正在寻找早期且无偏见的代码库来开始AI工程师的旅程Re......
  • java怎么控制输入数字的范围
    项目方案:Java数字范围输入控制1.简介在Java编程中,控制用户输入数字的范围是一个常见的需求。本项目方案通过提供一种可重复使用的方法来实现输入数字的范围控制,以确保用户输入的数字在指定的范围内。2.方案实现本方案通过编写一个自定义的输入控制类来实现对输入数字范围的控......