聚币网API[Python2版]
聚币 现货 API [Python2版]
一、utils.py,基础类,包括HTTP 请求、签名等
# -*- coding: utf-8 -*-
import hashlib
import hmac
import time
import urllib
import urllib2
import json
from datetime import datetime
from uuid import UUID
from objutil import dict_obj
# import requests
def http_get(url, data_wrap, encode=False):
if encode is True:
data_wrap = urllib.urlencode(data_wrap)
req = urllib2.Request(url, data=data_wrap)
resp = urllib2.urlopen(req).read()
dic = json.loads(resp)
return dict_obj(dic)
def get_signature(private_key, data):
data_en = urllib.urlencode(data)
md5_hash = getHash(private_key)
msg = bytes(data_en).encode('utf-8')
key = bytes(md5_hash).encode('utf-8')
signature = hmac.new(key, msg, digestmod=hashlib.sha256).digest()
last_warp = "%s&signature=%s" % (data_en, toHex(signature))
return last_warp
def get_nonce_time():
curr_stamp = time.time() * 100
return str(long(curr_stamp))
def getHash(s):
m = hashlib.md5()
m.update(s)
return m.hexdigest()
def toHex(str):
lst = []
for ch in str:
hv = hex(ord(ch)).replace('0x', '')
if len(hv) == 1:
hv = ' + hv
lst.append(hv)
return reduce(lambda x, y: x + y, lst)
def getUserData(cfg_file):
f = open(cfg_file, 'r')
account = {}
for i in f.readlines():
ctype, passwd = i.split('=')
account[ctype.strip()] = passwd.strip()
return account
class CJsonEncoder(json.JSONEncoder):
def default(self, obj):
if isinstance(obj, datetime):
return obj.strftime('%Y-%m-%d %H:%M:%S')
elif isinstance(obj, UUID):
return str(obj)
else:
return json.JSONEncoder.default(self, obj)
def json_dumps(result):
return json.dumps(result, cls=CJsonEncoder)
二、jubi.py,聚币网API
# -*- coding: utf-8 -*-
# @Author: wujiyu
# @Date: 2017-07-09 10:44:41
# @Last Modified by: far
# @Last Modified time: 2017-07-25 09:28:12
from utils import *
BASE_API = "https://www.jubi.com/api/v1"
TICKER_API = "%s/ticker" % BASE_API
DEPTH_API = "%s/depth" % BASE_API
ORDERS_API = "%s/orders" % BASE_API
BALANCE_API = "%s/balance" % BASE_API
TRADLIST_API = "%s/trade_list" % BASE_API
TRADEVIEW_API = "%s/trade_view" % BASE_API
TRADECANCEL_API = "%s/trade_cancel" % BASE_API
TRADEADD_API = "%s/trade_add" % BASE_API
class JuBi(object):
"""docstring for JuBi"""
def __init__(self):
super(JuBi, self).__init__()
cfg = getUserData('data.cfg')
self.public_key = cfg['public_key']
self.private_key = cfg['private_key']
def get_ticker(self, coin):
data_wrap = {'coin': coin}
return http_get(TICKER_API, data_wrap, True)
def get_depth(self, coin):
data_wrap = {'coin': coin}
return http_get(DEPTH_API, data_wrap, True)
def get_orders(self, coin):
data_wrap = {'coin': coin}
return http_get(ORDERS_API, data_wrap, True)
def get_balance(self):
nonce = get_nonce_time()
data_wrap = {'nonce': nonce,
'key': self.public_key}
all_data = get_signature(self.private_key, data_wrap)
return http_get(BALANCE_API, all_data)
def get_trade_list(self, coin):
# open:正在挂单, all:所有挂单
trade_type = "open"
since = "
nonce = get_nonce_time()
data_wrap = {'nonce': nonce, 'type': trade_type, 'coin': coin, 'since': since,
'key': self.public_key}
all_data = get_signature(self.private_key, data_wrap)
return http_get(TRADLIST_API, all_data)
def get_trade_view_list(self, coin, id):
nonce = get_nonce_time()
data_wrap = {'nonce': nonce, 'coin': coin,
'key': self.public_key, 'id': id}
all_data = get_signature(self.private_key, data_wrap)
return http_get(TRADEVIEW_API, all_data)
def cancel(self, coin, id):
nonce = get_nonce_time()
data_wrap = {'nonce': nonce, 'coin': coin,
'key': self.public_key, 'id': id}
all_data = get_signature(self.private_key, data_wrap)
return http_get(TRADECANCEL_API, all_data)
def trade_add(self, coin, amount, price, sell_type):
nonce = get_nonce_time()
data_wrap = {'nonce': nonce, 'coin': coin,
'key': self.public_key, 'amount': amount, "price": price, "type": sell_type}
all_data = get_signature(self.private_key, data_wrap)
return http_get(TRADEADD_API, all_data)
def sell(self, coin, amount, price):
return self.trade_add(coin, amount, price, "sell")
def buy(self, coin, amount, price):
return self.trade_add(coin, amount, price, "buy")
def cancel_all(self, coin, sell_type="all"):
lst = self.get_trade_list(coin)
print("当前挂单!!!!!!!!!!:%s" % (lst))
for item in lst:
if sell_type == "all" or sell_type == item["type"]:
self.cancel(coin, item["id"])
print("取消挂单成功!!!!!!!!!")
print("当前挂单!!!!!!!!!!:%s" % (self.get_trade_list(coin)))
return True
def cancel_all_sell(self, coin):
return self.cancel_all(coin, "sell")
def cancel_all_buy(self, coin):
return self.cancel_all(coin, "buy")
三、调用方法
coin = "btc" jubi = JuBi() print(jubi.get_ticker(coin)) # print(jubi.get_depth(coin)) # print(jubi.get_orders(coin)) # print(jubi.get_balance()) # print(jubi.get_trade_list(coin)) # print(jubi.get_trade_view_list(coin, "1")) # print(jubi.get_trade_cancel_list(coin, "1")) # print(jubi.sell(coin, 10000, 0.001)) # print(jubi.buy(coin, 100, 0.2)) # print(jubi.get_trade_cancel_list(coin, "1")) # print(jubi.cancel(coin, 940591))
四、下载地址
http://www.cnblogs.com/fangbei/p/jubi-api-python.html
http://files.cnblogs.com/files/fangbei/jubi-api-python2.zip
聚币网API[Python2版]的更多相关文章
- 聚币网API[Python3版]
代码 #!/usr/bin/env python # -*- coding:utf-8 -*- import hashlib import requests import time import ur ...
- 聚币网API使用教程 demo
原文 http://30daydo.com/article/181 目前还在完善,等功能完善了,就更新到csdn. 更新 2017-05-27 官方有API的文档,可是这个文档就像一个草稿一样,两个基 ...
- 火币网现货API[Python3版]
火币 期货 现货 API [Python3版] 一.Util.py,基础类,包括参数配置.签名,HTTP 请求方法,发送信息到API #coding=utf-8 import hashlib impo ...
- 淘宝网触屏版 - 学习笔记(1 - 关于meta)
注:本文是学习笔记,并不是教程,所以会有很多我不理解或猜测的问题,也会有不尽详实之处,望见谅. <meta charset="utf-8"> <meta cont ...
- 淘宝网触屏版 - 学习笔记(0 - 关于dpr)
注:本文是学习笔记,并不是教程,所以会有很多我不理解或猜测的问题,也会有不尽详实之处,望见谅. 对于pc端网页设计师来说,移动端的网页制作,我之前只是简单的加了一个 <meta name=&qu ...
- [转载]中国天气网API
最近在做个网站要用到天气网的api,在网上找了些参考资料,这篇文章对天气网api的介绍比较详细,所以转载之,谢谢原作者的辛勤劳动和奉献精神. 原文地址:http://g.kehou.com/t1033 ...
- OKCoin期货现货API[Python3版]
OKCoin 期货 现货 API [Python版] 一.HttpMD5Util.py,基础类,包括MD5签名,HTTP Post及HTTP Get方法 #!/usr/bin/python # -*- ...
- 火币Huobi API Websocket
本文介绍火币Huobi API Websocket WebSocket API简介 WebSocket协议是基于TCP的一种新的网络协议.它实现了客户端与服务器之间在单个 tcp 连接上的全双工通信, ...
- 火币Huobi API
本文介绍火币Huobi API REST API 简介 火币为用户提供了一套全新的API,可以帮用户快速接入火币PRO站及HADAX站的交易系统,实现程序化交易. 访问地址 适用站点 适用功能 适用交 ...
随机推荐
- Docker与KVM之间的区别
一.Docker简介 Docker 项目的目标是实现轻量级的操作系统虚拟化解决方案. Docker 的基础是 Linux 容器(LXC)等技术. 在 LXC 的基础上 Docker 进行了进一步的封装 ...
- Java8 Stream代码详解+BenchMark测试
Java8 Stream基础.深入.测试 1.基本介绍 1.创建方式 1.Array的Stream创建 1.直接创建 // main Stream stream = Stream.of("a ...
- Ajax的方法和使用代码
//1.创建Ajax对象,已经封装好的函数: function createXHR(){ if (typeof XMLHttpRequest != "undefined"){ re ...
- 【逻辑漏洞】基于BurpSuite的越权测试实战教程
一.什么是越权漏洞?它是如何产生的? 越权漏洞是Web应用程序中一种常见的安全漏洞.它的威胁在于一个账户即可控制全站用户数据.当然这些数据仅限于存在漏洞功能对应的数据.越权漏洞的成因主要是因为开发人员 ...
- ETL作业自动化调度软件TASKCTL4.5安装程序是选项解释
下文仅针对TASKCTL4.5有效,在执行安装程序后,会看到安装程序有4个选项,其中,1和2是需要了解的. 1, 典型安装: 这个选项是单机部署,在第一次使用TASKCTL的时候,我用的是这种安装方式 ...
- CentOS上javaweb开发环境搭建
CentOS上javaweb开发环境搭建 安装jdk yum list java* yum install java-1.7.0-openjdk* -y java -version 安装tomcat ...
- CLI子命令扩展-插件机制实现
开发CLI工具过程中,为了便于扩展,将CLI的实现分为基础功能和扩展功能.基础功能包括init.build.lint.publish等伴随工程从初始化到最终发布到生产环境,也即为CLI 的core.扩 ...
- swift 获取文件大小
//获取文件大小 func getSize(url: URL)->UInt64 { var fileSize : UInt64 = 0 do { let attr = try FileManag ...
- numastat的理解
numa的统计数据及理解如下, [root@localhost kernel]# numastat node0 node1numa_hit ...
- WebServices客户端代码生成
方式一: 官网下载cxf运行包:http://cxf.apache.org/download.html axis2:http://axis.apache.org/axis2/java/core/dow ...