La fonction de transaction Buy est utilisée./Sell () est une API que vous devez connaître.
[
ORDER_STATE_PENDING :未完成
ORDER_STATE_CLOSED :已关闭
ORDER_STATE_CANCELED :已取消
]
{
Id :交易单唯一标识
Price :下单价格
Amount :下单数量
DealAmount :成交数量
Status :订单状态, 参考常量里的订单状态
Type :订单类型, 参考常量里的订单类型
}
Documentation de l’API
Buy(Price, Amount) 下买单, Price为买单价格,Amount为数量, 返回一个订单ID
可以跟多余的参数做为附加消息显示到日志, 如exchange.Buy(1000,0.1, "OK", 123)
支持现货(火币/BitVC/OKCoin/OKCoin国际/OKCoin期货/BTCChina/BitYes)市价单, 市价单价格指定为-1
exchange.Buy(1000), 指买市价1000元的币, BTCChina例外exchange.Buy(0.3)指市价买0.3个币
Nous allons voir à quel point c’est simple d’utiliser le prix limite, et il y a en fait beaucoup de détails à traiter, nous allons d’abord les comprendre simplement, parce que plus tard, nous allons voir comment utiliser le prix limite.Chapitre 3 à 1Il y aura un processus très minutieux pour que vous appreniez.
function main() {
// 方便用户看这些 宏的值 我们事先打印出来
// ORDER_STATE_PENDING :未完成
// ORDER_STATE_CLOSED :已关闭
// ORDER_STATE_CANCELED :已取消
Log("ORDER_STATE_PENDING:", ORDER_STATE_PENDING, ", ORDER_STATE_CLOSED:",
ORDER_STATE_CLOSED, ", ORDER_STATE_CANCELED:", ORDER_STATE_CANCELED); // 这些都是订单状态的宏,打印这些值认识下,在本段代码不起任何作用,仅仅观察下这些 “状态” 的值。
var ticker = exchange.GetTicker(); // 上一章 已经讲述了怎么获取行情信息。
Log("初始账户信息:", exchange.GetAccount()); // 用于对比交易前后账户信息
var ID = exchange.Buy(ticker.Sell + 0.1, 0.1); // ticker.Sell 即 上一章中的 depth.Asks[0].Price 。
// 返回值是一个订单 ID ,参考上面 小准备。
// 限价单下单后 返回一个ID 可以用来查询这个订单的完成情况。我们暂停1秒 即: Sleep(1000) 。
Sleep(1000);
var order = exchange.GetOrder(ID); // 根据ID 获取 对应的 订单信息。
Log("order:", order);
Log("当前账户信息:", exchange.GetAccount()); // 对比初始账户信息
}
Voici les résultats:
On peut voir que le statut de l’ordre imprimé est 1, c’est-à-dire: ORDER_STATE_CLOSED 。 L’état actuel de l’ordre est terminé, voir dealAmount est 0.1, et confirmer que l’ordre a terminé la transaction。 Le montant de transaction est dealAmount 。 Les camarades qui ont peut-être observé attentivement ont trouvé que l’ordre imprimé était un AvgPrice (prix moyen de transaction) de plus que le document API, c’est parce que cet attribut est affiché plus tard dans l’extension。
Documentation de l’API
Sell(Price, Amount) 跟Buy函数一样的调用方法和场景
La fonction Buy () ci-dessus a été testée par le système de rétroaction que nous avons utilisé, et nous l’avons testée ici avec un simulateur de disque pour voir si la commande n’a pas été achetée (ou partiellement achetée).
function main() {
// 方便用户看这些 宏的值 我们事先打印出来
// ORDER_STATE_PENDING :未完成
// ORDER_STATE_CLOSED :已关闭
// ORDER_STATE_CANCELED :已取消
Log("ORDER_STATE_PENDING:", ORDER_STATE_PENDING, "
, ORDER_STATE_CLOSED:", ORDER_STATE_CLOSED, ", ORDER_STATE_CANCELED:", ORDER_STATE_CANCELED);
var ticker = exchange.GetTicker(); // 上一章 已经讲述了怎么获取行情信息。
Log("初始账户信息:", exchange.GetAccount()); // 用于对比交易前后账户信息
var ID = exchange.Sell(ticker.Sell + 0.3, 2); // 这里故意把卖出价格加了 0.3 ,并且使用的ticker.Sell,增加了未成交的几率。
// 返回值是一个订单 ID ,参考上面 小准备。
// 限价单下单后 返回一个ID 可以用来查询这个订单的完成情况。我们暂停1秒 即: Sleep(1000) 。
Sleep(1000);
var order = exchange.GetOrder(ID); // 根据ID 获取 对应的 订单信息。
Log("order:", order);
Log("当前账户信息:", exchange.GetAccount()); // 对比初始账户信息
}
Les inventeurs ont quantifié le fonctionnement de l’analogue comme suit:
Vous pouvez voir que le statut de l’ordre imprimé est de 0, c’est-à-dire qu’il n’est pas terminé. La valeur de DealAmount est de 0, et les 2 pièces vendues sont gelées car l’ordre est en attente.
Mais qu’en est-il du groupe Pending ? On utilise la fonction CancelOrder ((ID) pour annuler une commande avec un identifiant spécifié.
function main() {
// 方便用户看这些 宏的值 我们事先打印出来
// ORDER_STATE_PENDING :未完成
// ORDER_STATE_CLOSED :已关闭
// ORDER_STATE_CANCELED :已取消
Log("ORDER_STATE_PENDING:", ORDER_STATE_PENDING, ", ORDER_STATE_CLOSED:", ORDER_STATE_CLOSED,
", ORDER_STATE_CANCELED:", ORDER_STATE_CANCELED);
var ticker = exchange.GetTicker(); // 上一章 已经讲述了怎么获取行情信息。
Log("初始账户信息:", exchange.GetAccount()); // 用于对比交易前后账户信息
var ID = exchange.Sell(ticker.Sell + 50, 2); // ticker.Sell 即 上一章中的 depth.Asks[0].Price 。
// 返回值是一个订单 ID ,参考上面 小准备。
// 限价单下单后 返回一个ID 可以用来查询这个订单的完成情况。我们暂停1秒 即: Sleep(1000) 。
Sleep(1000);
var order = exchange.GetOrder(ID); // 根据ID 获取 对应的 订单信息。
Log("order:", order);
Log("当前账户信息:", exchange.GetAccount()); // 对比初始账户信息
Sleep(60 * 1000);
exchange.CancelOrder(ID); // 取消 这个ID 的订单
order = exchange.GetOrder(ID); // 读取这个ID的订单信息。
Log("order:", order);
}
Résultat de l’exécution: la commande avec le numéro d’identification 634795459 est affichée dans le dernier message de l’impression Status est de 2: ORDER_STATE_CANCELED: annulé

Les fonctions GetOrder ((ID) et GetOrders (()) se ressemblent beaucoup, mais la différence est que l’ancienne récupère les informations de commande de l’ID spécifié, tandis que la seconde récupère toutes les informations de commande de l’ID spécifié.未完成La structure de données renvoyée est un tableau d’objets, c’est-à-dire un tableau dans lequel chaque élément est une structure d’ordre).