监控聚币网行情 并实时发送到微信

Posted 左正

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了监控聚币网行情 并实时发送到微信相关的知识,希望对你有一定的参考价值。

最近由于好友推荐我入坑了国内的山寨币,所以顺便研究了下聚币网的API。 不过网页版的聚币网和手机版的做的不好,而且因为是7x24 小时交易,自己没有那么多的精力盯盘,所以写了python代码进行监控。

技术分享
# -*-coding=utf-8-*-
__author__ = ‘Rocky‘
‘‘‘
http://30daydo.com
Contact: [email protected]
‘‘‘
import random
import hashlib
import hmac,time
import smtplib
from email.mime.text import MIMEText
from email import Utils
import threading
import requests,datetime,itchat

from toolkit import Toolkit


class Jubi_web():
    def __init__(self, send=None):
        cfg = Toolkit.getUserData(‘data.cfg‘)
        self.public_key = cfg[‘public_key‘]
        self.private_key = cfg[‘private_key‘]
        self.send=send
        from_mail = cfg[‘from_mail‘]
        password = cfg[‘password‘]
        to_mail = cfg[‘to_mail‘]
        smtp_server = ‘smtp.qq.com‘

        self.server = smtp_server
        self.username = from_mail.split("@")[0]
        self.from_mail = from_mail
        self.password = password
        self.to_mail = to_mail
        self.coin_list=[‘IFC‘,‘DOGE‘,‘EAC‘,‘DNC‘,‘MET‘,‘ZET‘,‘SKT‘,‘YTC‘,‘PLC‘,‘LKC‘,
                        ‘JBC‘,‘MRYC‘,‘GOOC‘,‘QEC‘,‘PEB‘,‘XRP‘,‘NXT‘,‘WDC‘,‘MAX‘,‘ZCC‘,
                        ‘HLB‘,‘RSS‘,‘PGC‘,‘RIO‘,‘XAS‘,‘TFC‘,‘BLK‘,‘FZ‘,‘ANS‘,‘XPM‘,‘VTC‘,
                        ‘KTC‘,‘VRC‘,‘XSGS‘,‘LSK‘,‘PPC‘,‘ETC‘,‘GAME‘,‘LTC‘,‘ETH‘,‘BTC‘]
        # 初始化邮箱设置读取需要股票信息
        # 这样子只登陆一次
        if self.send == ‘msn‘:

            try:
                self.smtp = smtplib.SMTP_SSL(port=465)
                self.smtp.connect(self.server)
                self.smtp.login(self.username, self.password)
            except smtplib.SMTPException, e:
                print e
                return 0

        if send==‘wechat‘:
            self.w_name=u‘xxxxx‘
            
            itchat.auto_login(hotReload=True)
            account=itchat.get_friends(self.w_name)


    def send_wechat(self,name,content):
        w_content=name+‘ ‘+content
        itchat.send(w_content,toUserName=self.toName)
        time.sleep(1)
        itchat.send(w_content,toUserName=‘filehelper‘)


    def send_text(self, name, content):

        subject = ‘%s‘ % name
        self.msg = MIMEText(content, ‘plain‘, ‘utf-8‘)
        self.msg[‘to‘] = self.to_mail
        self.msg[‘from‘] = self.from_mail
        self.msg[‘Subject‘] = subject
        self.msg[‘Date‘] = Utils.formatdate(localtime=1)
        try:
            self.smtp.sendmail(self.msg[‘from‘], self.msg[‘to‘], self.msg.as_string())
            self.smtp.quit()
            print "sent"
        except smtplib.SMTPException, e:
            print e
            return 0

    def warming(self, coin, up_price, down_price):
        url = ‘https://www.jubi.com/api/v1/ticker/‘
        while 1:
            time.sleep(5)
            try:
                data = requests.post(url, data={‘coin‘: coin}).json()
            except Exception,e:
                print e
                print "time out. Retry"
                time.sleep(15)
                continue

            current = float(data[‘last‘])
            if current >= up_price:
                print "Up to ", up_price
                print "current price ",current

                if self.send==‘msn‘:
                    self.send_text(coin,str(current))
                if self.send==‘wechat‘:
                    self.send_wechat(coin,str(current))

                time.sleep(1200)
            if current <= down_price:
                print "Down to ", down_price
                print "current price ",current
                if self.send==‘msn‘:
                    self.send_text(coin,str(current))
                if self.send==‘wechat‘:
                    self.send_wechat(coin,str(current))
                time.sleep(1200)
    #上面的内容尽量不用修改。


    def getContent(self):
        url = ‘https://www.jubi.com/api/v1/trade_list‘
        params_data = {‘key‘: ‘x‘, ‘signature‘: ‘x‘}
        s = requests.get(url=url, params=params_data)

    def getHash(self, s):
        m = hashlib.md5()
        m.update(s)
        return m.hexdigest()

    def sha_convert(self, s):
        return hashlib.sha256(self.getHash(s)).hexdigest()

    def get_nonce(self):
        lens = 12
        return ‘‘.join([str(random.randint(0, 9)) for i in range(lens)])

    def get_signiture(self):
        url = ‘xxxxxxxxx‘
        coin = ‘zet‘
        nonce = self.get_nonce()

        # sha=self.sha_convert(private_key)
        md5 = self.getHash(self.private_key)
        message = ‘nonce=‘ + nonce + ‘&‘ + ‘key=‘ + self.public_key
        # print message
        signature = hmac.new(md5, message, digestmod=hashlib.sha256).digest()
        # print signature

        # req=requests.post(url,data={‘signature‘:signature,‘key‘:public_key,‘nonce‘:nonce,‘coin‘:‘zet‘})
        req = requests.post(url, data={‘coin‘: coin})
        print req.status_code
        print req.text

    def real_time_ticker(self, coin):
        url = ‘xxxxxxxx‘
        try:
            data = requests.post(url, data={‘coin‘: coin}).json()
            #print data
        except Exception ,e:
            print e
        return data


    def real_time_depth(self, coin):
        url = ‘xxxxxxxxx‘
        data = requests.post(url, data={‘coin‘: coin}).json()
        print data
        data_bids = data[‘bids‘]
        data_asks = data[‘asks‘]
        print "bids"
        for i in data_bids:
            print i[0],
            print ‘ ‘,
            print i[1]
        print "asks"
        for j in data_asks:
            print j[0],
            print ‘ ‘,
            print j[1]

    def list_all_price(self):
        for i in self.coin_list:
            print i,
            print " price: ",
            p=self.real_time_ticker(i.lower())
            if p is not None:
                print p[u‘last‘]

    def getOrder(self,coin):
        url=‘https://www.jubi.com/api/v1/orders/‘
        try:
            req=requests.get(url,params={‘coin‘:coin})
        except Exception,e:
            print e

        data=req.json()
        return data
    # recent 100 trade turn over
    def turnover(self,coin):
        i=coin.lower()
        coins=Toolkit.getUserData(‘coins.csv‘)
        total=long(coins[i])
[i]        [/i]p=self.getOrder(i)
        print p
        amount=0.00
        for j in p:
            t= j[u‘amount‘]
            amount=float(t)+amount
        #current=float(self.real_time_ticker(i)[u‘last‘])
        turn_over=amount*1.00/total*100
        print turn_over

    def multi_thread(self,coin_list,price_list):
        thread_num=len(coin_list)
        thread_list=
        for i in range(thread_num):
            t=threading.Thread(target=self.warming, args=(coin_list,price_list[0],price_list[1]),)
            thread_list.append(t)
        for j in thread_list:
            j.start()
        for k in thread_list:
            k.join()

if __name__ == ‘__main__‘:

    obj = Jubi_web(send=‘wechat‘)
    coin_list=[‘zet‘,‘doge‘]
    price_list=[[0.2,0.13],[0.03,0.024]]
    obj.multi_thread(coin_list,price_list)

[/i]


程序运行后,使用扫一扫登录。 

coin_list=[‘zet‘,‘doge‘] price_list=[[0.2,0.13],[0.03,0.024]]
 
通过这个参数,设置你想要监控的币种和目标价格。
同时程序支持发送给多个用户。
 

以上是关于监控聚币网行情 并实时发送到微信的主要内容,如果未能解决你的问题,请参考以下文章

聚币网API[Python2版]

聚币网API使用教程 demo

AAC登陆聚币,锐角云分布式存储之路还有多远?

Flask+Echarts+sqlite搭建股票实时行情监控

新浪财经美股期货实时行情怎么看

微信域名实时监控,域名被封立即通知的实现方法