python股票回测_Python量化交易-回测简单的交易策略

本文介绍如何使用Python进行股票回测,重点在于数据获取和交易逻辑的实现。通过获取A股历史数据,利用MongoDB存储,然后编写交易逻辑,包括周MACD分析,模拟交易操作并进行回测,展示不同年份的收益表现。
摘要由CSDN通过智能技术生成

这篇文章主要介绍如何使用Python对一些简单的交易策略进行回测,对这块比较感兴趣的朋友可以看一看。

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)

1.3.获取数据

获取证券数据的途径主要有两种,第一种是去网上找现成的数据接口,通过调用接口获取数据,这种方式简单便捷,数据的准确性有保障;第二种是自己编写数据爬虫获取数据,这种方式会相对麻烦一点。本文采用的是第一种方式。使用的数据接口是http://www.baostock.com/。

调用数据接口:

bs.login() # 初始化baostock

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

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值