返回介绍

第一部分 新手入门

第二部分 股票量化相关

第三部分 基金、利率互换、固定收益类

第四部分 衍生品相关

事件驱动策略示例——盈利预增

发布于 2022-02-20 22:26:14 字数 3073 浏览 1020 评论 0 收藏 0

策略思路

  • 从DataAPI中获取沪深300成分股的盈利预增事件数据
  • 每个交易日,将昨天发布盈利预增事件公司加入买入列表
  • 根据调仓限制和买入列表进行调仓
  • 调仓限制
    • (1) 股票持有不超过50只
    • (2) 一旦买入,持有40个交易日
    • (3) 仅当持有数量低于50只时才买入股票,补满50只
import pandas as pd
from datetime import datetime
from functools import partial

fields_ef = ['secID', 'publishDate']
get_data = partial(DataAPI.FdmtEfGet, forecastType = 22, field = fields_ef)  # forecastType 22: 盈利预增

data_ef = []
for stock in set_universe('HS300'):
    try:
        if len(data_ef):
            data_ef = data_ef.append(get_data(secID = stock))
        else:
            data_ef = get_data(secID = stock)
    except:
        pass

data_ef['publishDate'] = pd.to_datetime(data_ef['publishDate'])
data_ef = data_ef.sort(columns = 'publishDate')
data_ef = data_ef[data_ef.publishDate >= datetime(2010, 1, 1)]
start = '2010-01-01'
end   = '2015-04-01'
benchmark = 'HS300'
universe = set_universe('HS300')
capital_base = 1000000
longest_history = 1

max_t   = 40      # 持仓时间
max_n   = 50      # 持仓数量

def initialize(account):
    account.hold_period = {}

def handle_data(account):
    yesterday = account.get_symbol_history('tradeDate', 1)[0]
    data_sub = data_ef[data_ef.publishDate == yesterday]

    if len(data_sub):
        buylist = [s for s in data_sub['secID'].tolist() if s in account.universe]
        rebalance(account, buylist)

def rebalance(account, buylist):
    n = 0
    for stock, t in account.hold_period.items():
        if t == max_t:
            order_to(stock, 0)
            del account.hold_period[stock]
        else:
            account.hold_period[stock] += 1
            n += 1
    if n == max_n or buylist == []:
        return

    b = max_n - n
    buylist = [s for s in buylist if s not in account.hold_period]
    for stock in buylist[:b]:
        order(stock, account.referencePortfolioValue / b / account.referencePrice[stock])
        account.hold_period[stock] = 0

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文