# -*- coding:utf-8 -*- __author__ = 'weijie' from EmQuantAPI import * from datetime import timedelta, datetime import time as _time import traceback import requests import re from dbOperationStock import dbOperationStock import db_config print("开始了") def mainCallback(quantdata): print ("mainCallback",str(quantdata)) #登录掉线或者 登陆数达到上线(即登录被踢下线) 这时所有的服务都会停止 if str(quantdata.ErrorCode) == "10001011" or str(quantdata.ErrorCode) == "10001009": print ("Your account is disconnect. You can force login automatically here if you need.") #行情登录验证失败(每次连接行情服务器时需要登录验证)或者行情流量验证失败时,会取消所有订阅,用户需根据具体情况处理 elif str(quantdata.ErrorCode) == "10001021" or str(quantdata.ErrorCode) == "10001022": print ("Your all csq subscribe have stopped.") #行情服务器断线自动重连连续6次失败(1分钟左右)不过重连尝试还会继续进行直到成功为止,遇到这种情况需要确认两边的网络状况 elif str(quantdata.ErrorCode) == "10002009": print ("Your all csq subscribe have stopped, reconnect 6 times fail.") # 行情订阅遇到一些错误(这些错误会导致重连,错误原因通过日志输出,统一转换成EQERR_QUOTE_RECONNECT在这里通知),正自动重连并重新订阅,可以做个监控 elif str(quantdata.ErrorCode) == "10002012": print ("csq subscribe break on some error, reconnect and request automatically.") # 资讯服务器断线自动重连连续6次失败(1分钟左右)不过重连尝试还会继续进行直到成功为止,遇到这种情况需要确认两边的网络状况 elif str(quantdata.ErrorCode) == "10002014": print ("Your all cnq subscribe have stopped, reconnect 6 times fail.") # 资讯订阅遇到一些错误(这些错误会导致重连,错误原因通过日志输出,统一转换成EQERR_INFO_RECONNECT在这里通知),正自动重连并重新订阅,可以做个监控 elif str(quantdata.ErrorCode) == "10002013": print ("cnq subscribe break on some error, reconnect and request automatically.") # 资讯登录验证失败(每次连接资讯服务器时需要登录验证)或者资讯流量验证失败时,会取消所有订阅,用户需根据具体情况处理 elif str(quantdata.ErrorCode) == "10001024" or str(quantdata.ErrorCode) == "10001025": print("Your all cnq subscribe have stopped.") else: pass def cnqCallback(quantdata): db = dbOperationStock(db_config.db_stock) for code in data.Data: # total = len(data.Data[code]) for k in range(0, len(data.Data[code])): # print(data.Data[code][k]) # print(data.Data[code][k][7]) se = requests.session() url = "http://app.jg.eastmoney.com/NewsData/GetNewsText.do?cid=Admin&cid=Admin&id=" + data.Data[code][k][5] dfNews = se.post(url).text.replace("'", '"').replace('/ ', '/') dfNew = eval(dfNews) # print(dfNew) content = str(dfNew['text']).replace("","/span>") pattern = 'https://z1.*?\.jpg' p2 = re.findall(pattern, str(content)) # print(p2) imgUrl = "http://47.96.39.5:8080/public/default.png" if(0 != len(p2)) : imgUrl = p2[0] sql = "insert into `news` (`title`, `cover`, `content`, `source`, `hot`, `publish_time`, `create_time`, `update_time`) values('" + str(dfNew['Title']) + "', '" + str(imgUrl) + "', '" + str(content) +"', '" + str(dfNew['medianame']) + "',0,'" + str(dfNew['Date']) + "',now(),now());" # print(sql) db.insert(sql) db.close() try: #调用登录函数(激活后使用,不需要用户名密码) loginResult = c.start("ForceLogin=1", '', mainCallback) if(loginResult.ErrorCode != 0): print("login in fail") exit() # 资讯查询使用范例 data = c.cfn("S888005002API", "sectornews", eCfnMode_EndCount, "starttime=20201106010000,endtime=20201107,count=10") print("cfn输出结果======分隔线======") if (not isinstance(data, c.EmQuantData)): print (data) else: if (data.ErrorCode != 0): print("request cfn Error, ", data.ErrorMsg) else: db = dbOperationStock(db_config.db_stock) for code in data.Data: # total = len(data.Data[code]) for k in range(0, len(data.Data[code])): # print(data.Data[code][k]) # print(data.Data[code][k][7]) se = requests.session() url = "http://app.jg.eastmoney.com/NewsData/GetNewsText.do?cid=Admin&cid=Admin&id=" + data.Data[code][k][5] dfNews = se.post(url).text.replace("'", '"').replace('/ ', '/') dfNew = eval(dfNews) # print(dfNew) content = str(dfNew['text']).replace("","/span>") pattern = 'https://z1.*?\.jpg' p2 = re.findall(pattern, str(content)) # print(p2) imgUrl = "http://47.96.39.5:8080/public/default.png" if(0 != len(p2)) : imgUrl = p2[0] sql = "insert into `news` (`title`, `cover`, `content`, `source`, `hot`, `publish_time`, `create_time`, `update_time`) values('" + str(dfNew['Title']) + "', '" + str(imgUrl) + "', '" + str(content) +"', '" + str(dfNew['medianame']) + "',0,'" + str(dfNew['Date']) + "',now(),now());" # print(sql) db.insert(sql) db.close() # # 资讯订阅使用范例 S888005009API 昨日涨停 data = c.cnq("S888005002API","sectornews","",cnqCallback) if data.ErrorCode != 0: print("request cnq Error, ", data.ErrorMsg) else: print("cnq输出结果======分隔线======") text = input("press any key to cancel cnq \r\n") # 取消订阅 data = c.cnqcancel(data.SerialID) #退出 data = logoutResult = c.stop() except Exception as ee: print("error >>>",ee) traceback.print_exc() else: print("demo end")