yinhm / easytrader

提供券商华泰/佣金宝/银河的基金、股票自动程序化交易

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

easytrader

  • 进行自动的程序化股票交易
  • 实现自动登录
  • 支持命令行调用,方便其他语言适配
  • 支持 Python3 / Python2
  • 有兴趣的可以加群 429011814 一起讨论

开发环境 : Ubuntu 15.10 / Python 3.5

相关

获取新浪免费实时行情的类库: easyquotation

简单的股票量化交易框架 使用 easytrader 和 easyquotation

捐助: 支付宝 微信

支持券商

  • 佣金宝
  • 华泰
  • 银河 (感谢 ruyiqf 的贡献)

requirements

pip install -r requirements.txt

华泰 / 佣金宝 的自动登录需要安装以下二者之一:

  • JAVA : 推荐, 识别率高,安装简单, 需要命令行下 java -version 可用 (感谢空中园的贡献)
  • tesseract : 保证在命令行下 tesseract 可用

用法

引入:

import easytrader

设置账户:

佣金宝
user = easytrader.use('yjb') # 佣金宝支持 ['yjb', 'YJB', '佣金宝']
华泰
user = easytrader.use('ht') # 华泰支持 ['ht', 'HT', '华泰']
银河
user = easytrader.use('yh') # 银河支持 ['yh', 'YH', '银河']
自动登录
user.prepare('ht.json') // 或者 yjb.json 或者 yh.json

:

  • 华泰需要配置 ht.json 填入相关信息, trdpwd 加密后的密码首次需要登录后查看登录 POSTtrdpwd 值确定
  • 佣金宝需要配置 yjb.json 并填入相关信息, 其中的 password 为加密后的 password
  • 银河需要配置 yh.json 填入相关信息, trdpwd 加密后的密码首次需要登录后查看登录 POSTtrdpwd 值确定, 以及登录POST请求里面的hardinfo字段

如何获取配置所需信息, 可参考此文章

交易相关

以下用法以佣金宝为例,华泰类似

获取资金状况:

user.balance

return

[{ 'asset_balance': '资产总值',
   'current_balance': '当前余额',
   'enable_balance': '可用金额',
   'market_value': '证券市值',
   'money_type': '币种',
   'pre_interest': '预计利息' ]}

获取持仓:

user.position

return

[{'cost_price': '摊薄成本价',
   'current_amount': '当前数量',
   'enable_amount': '可卖数量',
   'income_balance': '摊薄浮动盈亏',
   'keep_cost_price': '保本价',
   'last_price': '最新价',
   'market_value': '证券市值',
   'position_str': '定位串',
   'stock_code': '证券代码',
   'stock_name': '证券名称'}]

获取今日委托单

user.entrust

return

[{'business_amount': '成交数量',
  'business_price': '成交价格',
  'entrust_amount': '委托数量',
  'entrust_bs': '买卖方向',
  'entrust_no': '委托编号',
  'entrust_price': '委托价格',
  'entrust_status': '委托状态',  # 废单 / 已报
  'report_time': '申报时间',
  'stock_code': '证券代码',
  'stock_name': '证券名称'}]

买入:

user.buy('162411', price=0.55, amount=100)

return

[{'entrust_no': '委托编号',
  'init_date': '发生日期',
  'batch_no': '委托批号',
  'report_no': '申报号',
  'seat_no': '席位编号',
  'entrust_time': '委托时间',
  'entrust_price': '委托价格',
  'entrust_amount': '委托数量',
  'stock_code': '证券代码',
  'entrust_bs': '买卖方向',
  'entrust_type': '委托类别',
  'entrust_status': '委托状态',
  'fund_account': '资金帐号',
  'error_no': '错误号',
  'error_info': '错误原因'}]

卖出:

user.sell('162411', price=0.55, amount=100)

撤单

华泰
user.cancel_entrust('委托单号')
佣金宝
user.cancel_entrust('委托单号', '股票代码')
银河证券
user.cancel_entrust('委托单号', '股票代码')

银河证券场内基金功能

基金认购
user.fundsubscribe('基金代码', '基金份额')
基金申购
user.fundpurchase('基金代码', '基金份额')
基金赎回
user.fundredemption('基金代码', '基金份额')
基金合并
user.fundmerge('基金代码', '基金份额')
基金拆分
user.fundsplit('基金代码', '基金份额')

命令行模式

登录

 python cli.py --use ht --prepare ht.json 

注: 此时会生成 account.session 文件保存生成的 user 对象

获取余额 / 持仓 / 以及其他变量

 python cli.py --get balance

买卖 / 撤单

 python cli.py --do buy 162411 0.450 100

查看帮助

 python cli.py --help

Q&A

Question

编辑完配置文件,运行后出现 json 解码报错的信息。类似于下面

raise JSONDecodeError("Expecting value", s, err.value) from None

JSONDecodeError: Expecting value
Answer

请勿使用 记事本 编辑账户的 json 配置文件,推荐使用 notepad++ 或者 sublime text

其他

交易接口分析以及其他开源量化相关论坛

软件实现原理

About

提供券商华泰/佣金宝/银河的基金、股票自动程序化交易


Languages

Language:Python 100.0%