我来提供一个思路,用Python对一些简单的交易策略进行回测,对这块感兴趣的可以看一看。

主要分为以下几步:

1.获取证券数据

2.编写交易逻辑

3.模拟交易操作

4.统计结果和绘图

1.获取证券数据

首先我们明确一个问题,这个交易策略将会被用在哪个市场?这样我们才能有针对性的获取数据。本文以A股市场为例,先获取A股近10年的数据并保存到数据库。

1.1.安装数据库(MongoDB)

为了提升运行效率,需要将证券数据保存到本地数据库,这里我们选择的数据库是MongoDB,安装过程在此不再赘述,参照http://www.runoob.com/mongodb/mongodb-window-install.html即可,比较简单。

1.2.编写数据库操作类

安装完数据库,我们编写一个工具类来管理数据库的增删改查等操作:

class DBManager:

def __init__(self, table_name):

self.client = MongoClient("127.0.0.1", 27017)

self.db = self.client["my_database"]

self.table = self.db[table_name]

def clsoe_db(self):

self.client.close()

# 获取股票代码列表(sz格式)

def get_code_list(self):

return self.table.find({}, {"ticker": 1}, no_cursor_timeout=True)

# 查询多条数据

def find_by_key(self, request=None):

if request is None:

request = {}

return self.table.find(request)

# 查询单条数据

def find_one_by_key(self, request=None):

if request is None:

request = {}

return self.table.find_one(request)

# 添加单条数据

def add_one(self, post, created_time=datetime.datetime.now()):

# 添加一条数据

post['created_time'] = created_time

return self.table.insert_one(post)

# 添加历史交易记录

def add_tk_item(self, ticker, __dict):

return self.table.update_one({'ticker': ticker}, {"$push": {"data_list": __dict}})

1.3.获取数据

获取证券数据的途径分为两种,第一种是去网上找现成的数据接口,通过调用接口获取数据,这种方式的优点在于简单便捷,数据的准确性有保障;第二种是自己编写数据爬虫获取数据,这种方式会相对麻烦一点,但如果你对数据的时效性要求较高,或者数据接口中的数据不能满足你的需求,可以选择第二种方式。本文采用的是第一种方式。使用的数据接口是http://www.baostock.com/。

调用接口:

bs.login() # 初始化baostock

code_list = dm.get_code_list() # 获取股票代码列表

for item in code_list:

max_try = 8 # 失败重连的最大次数

ticker = item["ticker"]

for tries in range(max_try):

rs = bs.query_history_k_data(ticker, "date,code,open,high,low,close,volume,amount,adjustflag,turn,"

"pctChg", frequency="w", adjustflag="3")

if rs.error_code == '0':

parse_pager(rs, ticker) # 解析数据

break

elif tries < (max_try - 1):

sleep(2)

continue

else:

log.logger.error("加载数据失败:" + str(ticker))

log.logger.info("加载数据完成")

bs.logout()

解析数据:

# 解析数据并保存到数据库

def parse_pager(content, ticker):

while content.next():

item_row = content.get_row_data()

__dict = {

"date": item_row[0],

"code": item_row[1],

"open": item_row[2],

"high": item_row[3],

"low": item_row[4],

"close": item_row[5],

"volume": item_row[6],

"amount": item_row[7],

"adjustflag": item_row[8],

"turn": item_row[9],

"pctChg": item_row[10]

}

dm.add_tk_item(ticker, __dict) # 将数据保存到数据库

2.编写交易逻辑

为了便于描述,本次我们选择了一个较为简单的交易逻辑。以周为交易周期,每周一开盘前分析各股的周macd数据,满足交易条件则以开盘价买入并持有一周,以当周五的收盘价卖出。这个交易逻辑非常简单,回测的表现也有可圈可点之处(回测结果见文末),但离实盘交易还有一定的距离。交易逻辑的核心代码如下:

if wmacd_list[-1] > 0 >= wmacd_list[-2]:

if np.mean(volume_list[-5:-1]) < volume_list[-1]:

if 0.1 >= diff_list[-1] >= 0:

data = [x for x in dm_tk.find_one_by_key({"ticker": item["ticker"]})["data_list"] if x["date"] == cur_date][0]

result_list.append(data)

def get_w_macd(price_list):

ema_12_list = list()

for index in range(len(price_list)):

if index == 0:

ema_12_list.append(price_list[0])

else:

ema_12_list.append(round(ema_12_list[index - 1] * 11 / 13 + price_list[index] * 2 / 13, 4))

ema_26_list = list()

for index in range(len(price_list)):

if index == 0:

ema_26_list.append(price_list[0])

else:

ema_26_list.append(round(ema_26_list[index - 1] * 25 / 27 + price_list[index] * 2 / 27, 4))

diff_list = list()

for index in range(len(ema_12_list)):

diff = ema_12_list[index] - ema_26_list[index]

diff_list.append(diff)

dea_list = list()

for index in range(len(diff_list)):

if index == 0:

dea_list.append(diff_list[0])

else:

dea_list.append(round(dea_list[index - 1] * 0.8 + diff_list[index] * 0.2, 4))

wmacd_list = list()

for index in range(len(dea_list)):

bar = (diff_list[index] - dea_list[index]) * 3

wmacd_list.append(bar)

return wmacd_list, diff_list, dea_list

对于交易逻辑我只截取了其中的一小部分,因为这段代码相对来说比较复杂,而且读者也不需要看懂其中的逻辑,实际开发过程中肯定会使用自己的交易逻辑而不是这个。

3.模拟交易操作

明确好交易逻辑后,我们就可以开始模拟交易操作了。首先我们初始化一些数据,这些数据在我们日常交易中也非常常见,比如起始资金、当前可用资金、交易周期、持仓列表、最大仓位等等,由于我们的交易策略比较简单,所以我们只要初始化起始资金就可以了:

capital_base = 1000000 # 起始资金设定为100万

history_capital = list() # 用于记录交易结果

接下来我们创建一条时间轴,所有的交易操作都将跟随时间轴进行:

# 生成时间轴

def date_range(start, end, step=1, format="%Y-%m-%d"):

strptime, strftime = datetime.datetime.strptime, datetime.datetime.strftime

days = (strptime(end, format) - strptime(start, format)).days + 1

return [strftime(strptime(start, format) + datetime.timedelta(i), format) for i in range(0, days, step)]

date_list = date_range("2016-01-01", "2016-12-31") # 生成2016-01-01至2016-12-31的所有时间点

生成好时间轴后,使用for循环遍历时间轴,按照之前设定的交易逻辑,我们需要在每周一和周五进行操作,由于该策略不涉及加减仓,故我们对交易过程就行了简化,用直接计算得到的结果替代了买入卖出的操作,对于更为复杂的交易策略,开发者需要分别实现开仓、平仓和加减仓等各种操作:

for cur_date in date_list:

if datetime.datetime.strptime(cur_date, "%Y-%m-%d").weekday() == 4: # 判断当前日期是否需要操作

result_list = list() # 用于记录当前时间符合交易条件的股票代码

for item in code_list: # 遍历各支股票,筛选出符合交易条件的股票

-执行交易逻辑-

if 符合交易条件:

result_list.append(data)

# 计算结果

if result_list:

capital = capital_base / len(result_list) # 对当前资金进行均分

temp_capital = 0

for item in result_list:

close_price = float(item["close"])

open_price = float(item["open"])

max_price = float(item["high"])

profit = (close_price - open_price) / open_price

temp_capital += (capital * (1 + profit))

capital_base = temp_capital

history_capital.append(capital_base) # 记录本次操作后剩余的资金

4.统计结果和绘图

模拟交易完成后我们来对结果进行统计,由于我们已经将交易的结果记录在history_capital中,此时我们可以轻松的计算出收益率:

net_rate = (history_capital[-1] - history_capital[0]) / history_capital[0] # 计算回测结果

log.logger.info("total_profit:" + str(round(net_rate * 100, 2)) + "%")

为了让交易的结果更加直观,我们还可以将其绘制成折线图,使用matplotlib进行绘图:

plt.subplot(111)

lable_x = np.arange(len(history_capital))

plt.plot(lable_x, history_capital, color="r", linewidth=1.0, linestyle="-")

plt.xlim(lable_x.min(), lable_x.max() * 1.1)

plt.ylim(min(history_capital) * 0.9, max(history_capital) * 1.1)

plt.grid(True)

plt.show()

回测结果展示:2014.png2015.png2016.png2017.png

到此为止,就实现了使用Python对某个交易策略进行回测的全部流程,读者可以自由变换交易逻辑来获取更多不同的结果,通过对回测结果进行分析,或许可以对我们日常的交易带来一点帮助。

与我交流:1003882179@qq.com

北上资金 python_你都用 Python 来做什么?相关推荐

  1. 你都用python来做什么-你都用Python来做什么?看看网友们的各种牛X操作

    原标题:你都用Python来做什么?看看网友们的各种牛X操作 关于Python有一句名言:不要重复造轮子. 但是问题有三个: 一.你不知道已经有哪些轮子已经造好了,哪个适合你用.有名有姓的的著名轮子就 ...

  2. 转知乎的文章 都用 Python 来做什么啊

    大家都用 Python 来做什么啊? Tsing:谁说我是来看段子的... 首先上一首Python之禅: Python是一个非常好用的程序语言,开发的速度非常快.我用Python已经一年多了,从Pyt ...

  3. 你都用python来做什么-你都用 Python 来做什么?

    说一下在日常工作中我都用Python做什么吧,Excel大家一定都不陌生了,在工作中也一定会涉及到统计数据等,我一直都利用Python对数据写入Execl文件并生成图表. 为了做测试或者对爬虫程序爬取 ...

  4. python能帮我们实现什么用_你都用 Python 来做什么?

    「除了生孩子,Python 啥都能做!!!」这句话最近实在是有些火啊,难道 Python 就真的这么强吗?当然,不信咱们可以看一下数据 这是近期 TIOBE 公布的 2019 年 10 月编程语言排行 ...

  5. python分类模型干嘛的_你都用 Python 来做什么?

    作为计算机专业的学生,主要学习的是c++.在大二选修了python,如今过去了一年,可以说这一年里python对我来说用处颇多.下面就列举一下我学习python到现在都用它来做了什么. 1. 学pyt ...

  6. wxpython是干嘛的_你都用 Python 来做什么?

    当时为了完成学校举办的一个训练计划,我自己翻阅各类文献,用python做用来识别手指静脉纹路的软件,GUI用wxpython编写,项目的具体介绍在如下链接:bmxbmx3/Finger_Vein_Re ...

  7. python3能做什么_你都用 Python 来做什么?

    python能做的有很多,我这里之阐述我自学的数据分析的内容,这也是我学习利用python进行数据分析的过程,如果要看实践可以直接看项目篇 数据分析中常用的软件是jupyter notebook,而应 ...

  8. 只安装python能干什么_你都用 Python 来做什么?

    人在美国,刚下飞机,这个问题要先拉一拉时间轴2016年第一次接触 python,做的是自动化测试 2017年开始自学 python,做的是投票网页开发 2018年正式接触 python,做的是WAF机 ...

  9. 北上资金 python_股票数据抓取——北上基金持股数据(selenium抓取数据),爬取,之,北向,资金,通过...

    目前很多网站对爬虫都有防范措施,传统的爬数据方法不一定有效.我们只能曲线救国,通过模拟网页浏览方式爬取数据,虽然速度慢,既能达到目标又不会网站服务器增加压力,双赢吧. Python环境要先下载sele ...

最新文章

  1. 混合线性模型+mixed linear model+GEEs+GLMM+LMM
  2. ie6 ie7 绝对定位 相对定位 层被遮住
  3. 进程特征码遍历VC版
  4. BuckleScript 1.0发布,面向OCaml的开源JavaScript编译器
  5. pycharm下找不到要安装的模块包(如sqlalchemy)
  6. wxWidgets:创建自定义小部件
  7. java 中 的 字节流!
  8. 微信公众平台消息接口开发(2)
  9. APUE读书笔记-15进程内部通信-05FIFOs
  10. keras + tensorflow 基本使用 —— backend
  11. python爬虫之路——对斗破苍穹进行关键字提取,制作噪声云图
  12. SI9000常用共面阻抗模型的解释
  13. 税控盘版增值税开票软件日志加密算法分析及解密工具
  14. 瑞斯康达raisecom交换机基础配置
  15. linux可变剪切分析,生信实操|一个生信素人的上道经验分享-转录组测序(可变剪接篇)...
  16. 基于二叉树的家谱系统
  17. python flask 微信_使用Flask创建微信公众号
  18. java实现客户端 与服务端的对话_Socket实现单客户端与服务器对话功能
  19. Mysql的日志详解(详细)
  20. 记录使用scrapy爬取新闻网站最新新闻存入MySQL数据库,每天定时爬取自动更新

热门文章

  1. ROS学习笔记-roslaunch文件的编写用sh脚本控制launch文件启动顺序
  2. 区块链安全:闪电贷 Flashloan
  3. 九、管理SEO团队的7个常见问题
  4. Unity 如何设计UI管理系统
  5. 为何“迷你本”退货率很高?
  6. 【无标题】公安机关办理刑事案件程序规定讲义
  7. 微信直播如何引流获客?
  8. MongoDB实战系列之五:mongodb的分片配置
  9. 使用pyspark 进行向量计算
  10. 如何使用Java、Servlet创建二维码