# 本代码由可视化策略环境自动生成 2022年10月25日 15:52
# 本代码单元只能在可视化模式下编辑。您也可以拷贝代码,粘贴到新建的代码单元或者策略,然后修改。
pd.set_option('display.max_rows',None)
# 回测引擎:初始化函数,只执行一次
def m5_initialize_bigquant_run(context):
# 加载股票指标数据,数据继承自m6模块
context.indicator_data = context.options['data'].read_df()
# 系统已经设置了默认的交易手续费和滑点,要修改手续费可使用如下函数
context.set_commission(PerOrder(buy_cost=0.0003, sell_cost=0.0013, min_cost=5))
# 设置股票数量
context.stock_num = 5
# 调仓天数,22个交易日大概就是一个月。可以理解为一个月换仓一次
# context.rebalance_days = 22
context.rebalance_days = 2
# 如果策略运行中,需要将数据进行保存,可以借用extension这个对象,类型为dict
# 比如当前运行的k线的索引,比如个股持仓天数、买入均价
# print('context.extension',context.extension)
if 'index' not in context.extension:
context.extension['index'] = 0
# print('context.extension',context.extension)
# 回测引擎:每日数据处理函数,每天执行一次
def m5_handle_data_bigquant_run(context, data):
context.extension['index'] += 1
# 不在换仓日就return,相当于后面的代码只会一个月运行一次,买入的股票会持有1个月
# if context.extension['index'] % context.rebalance_days != 0:
if context.extension['index'] % context.rebalance_days != 0:
# return
# 当前的日期
date = data.current_dt.strftime('%Y-%m-%d')
print('date',date)
cur_data = context.indicator_data[context.indicator_data['date'] == date]
# print('cur_data',cur_data)
# print('indicator_dat',context.indicator_dat)
# 根据日期获取调仓需要买入的股票的列表
stock_to_buy = list(cur_data.instrument[:context.stock_num])
# print('stock_to_buy',stock_to_buy)
# 通过positions对象,使用列表生成式的方法获取目前持仓的股票列表
stock_hold_now = [equity.symbol for equity in context.portfolio.positions]
# print('stock_hold_now',stock_hold_now)
# 继续持有的股票:调仓时,如果买入的股票已经存在于目前的持仓里,那么应继续持有
no_need_to_sell = [i for i in stock_hold_now if i in stock_to_buy]
# 需要卖出的股票
stock_to_sell = [i for i in stock_hold_now if i not in no_need_to_sell]
# 卖出
for stock in stock_to_sell:
# 如果该股票停牌,则没法成交。因此需要用can_trade方法检查下该股票的状态
# 如果返回真值,则可以正常下单,否则会出错
# 因为stock是字符串格式,我们用symbol方法将其转化成平台可以接受的形式:Equity格式
if data.can_trade(context.symbol(stock)):
# order_target_percent是平台的一个下单接口,表明下单使得该股票的权重为0,
# 即卖出全部股票,可参考回测文档
context.order_target_percent(context.symbol(stock), 0)
# 如果当天没有买入的股票,就返回
if len(stock_to_buy) == 0:
return
# 等权重买入
weight = 1 / len(stock_to_buy)
print('weight',weight)
# 买入
for stock in stock_to_buy:
if data.can_trade(context.symbol(stock)):
# 下单使得某只股票的持仓权重达到weight,因为
# weight大于0,因此是等权重买入
context.order_target_percent(context.symbol(stock), weight)
# 回测引擎:准备数据,只执行一次
def m5_prepare_bigquant_run(context):
pass
# 回测引擎:每个单位时间开始前调用一次,即每日开盘前调用一次。
def m5_before_trading_start_bigquant_run(context, data):
pass
m1 = M.instruments.v2(
start_date=T.live_run_param('trading_date', '2022-08-24'),
end_date=T.live_run_param('trading_date', '2022-10-25'),
market='CN_STOCK_A',
instrument_list='',
max_count=0
)
m2 = M.input_features.v1(
features="""market_cap_float_0
amount_0"""
)
m3 = M.general_feature_extractor.v7(
instruments=m1.data,
features=m2.data,
start_date='',
end_date='',
before_start_days=1
)
m4 = M.sort.v4(
input_ds=m3.data,
sort_by='market_cap_float_0',
group_by='instrument',
keep_columns='--',
ascending=True
)
m6 = M.filter.v3(
input_data=m4.sorted_data,
expr='amount_0 > 10000',
output_left_data=False
)
m5 = M.trade.v4(
instruments=m1.data,
options_data=m6.data,
start_date='',
end_date='',
initialize=m5_initialize_bigquant_run,
handle_data=m5_handle_data_bigquant_run,
prepare=m5_prepare_bigquant_run,
before_trading_start=m5_before_trading_start_bigquant_run,
volume_limit=0,
order_price_field_buy='open',
order_price_field_sell='open',
capital_base=1000000,
auto_cancel_non_tradable_orders=True,
data_frequency='daily',
price_type='前复权',
product_type='股票',
plot_charts=True,
backtest_only=False,
benchmark=''
)
[2022-10-28 14:11:24.860705] INFO: moduleinvoker: instruments.v2 开始运行..
[2022-10-28 14:11:24.901904] INFO: moduleinvoker: 命中缓存
[2022-10-28 14:11:24.906641] INFO: moduleinvoker: instruments.v2 运行完成[0.045941s].
[2022-10-28 14:11:24.933072] INFO: moduleinvoker: input_features.v1 开始运行..
[2022-10-28 14:11:24.947346] INFO: moduleinvoker: 命中缓存
[2022-10-28 14:11:24.951413] INFO: moduleinvoker: input_features.v1 运行完成[0.018346s].
[2022-10-28 14:11:25.015069] INFO: moduleinvoker: general_feature_extractor.v7 开始运行..
[2022-10-28 14:11:25.028640] INFO: moduleinvoker: 命中缓存
[2022-10-28 14:11:25.032556] INFO: moduleinvoker: general_feature_extractor.v7 运行完成[0.017495s].
[2022-10-28 14:11:25.050245] INFO: moduleinvoker: sort.v4 开始运行..
[2022-10-28 14:11:25.066958] INFO: moduleinvoker: 命中缓存
[2022-10-28 14:11:25.075698] INFO: moduleinvoker: sort.v4 运行完成[0.025417s].
[2022-10-28 14:11:25.111841] INFO: moduleinvoker: filter.v3 开始运行..
[2022-10-28 14:11:25.125551] INFO: moduleinvoker: 命中缓存
[2022-10-28 14:11:25.132077] INFO: moduleinvoker: filter.v3 运行完成[0.020232s].
[2022-10-28 14:11:31.001493] INFO: moduleinvoker: backtest.v8 开始运行..
[2022-10-28 14:11:31.012374] INFO: backtest: biglearning backtest:V8.6.3
[2022-10-28 14:11:31.015191] INFO: backtest: product_type:stock by specified
[2022-10-28 14:11:31.246420] INFO: moduleinvoker: cached.v2 开始运行..
[2022-10-28 14:11:31.262243] INFO: moduleinvoker: 命中缓存
[2022-10-28 14:11:31.265142] INFO: moduleinvoker: cached.v2 运行完成[0.018801s].
[2022-10-28 14:11:41.461362] INFO: backtest: algo history_data=DataSource(dd1b49c6eadd4dcc9783e38ec1b9fddeT)
[2022-10-28 14:11:41.464350] INFO: algo: TradingAlgorithm V1.8.8
[2022-10-28 14:11:42.504895] INFO: algo: trading transform...
[2022-10-28 14:11:43.423944] INFO: algo: handle_splits get splits [dt:2022-09-29 00:00:00+00:00] [asset:Equity(4418 [870299.BJA]), ratio:0.9790077805519104]
[2022-10-28 14:11:43.429011] INFO: Position: position stock handle split[sid:4418, orig_amount:41700, new_amount:42594.0, orig_cost:5.153527722442421, new_cost:5.0453, ratio:0.9790077805519104, last_sale_price:5.130001068115234]
[2022-10-28 14:11:43.433114] INFO: Position: after split: PositionStock(asset:Equity(4418 [870299.BJA]), amount:42594.0, cost_basis:5.0453, last_sale_price:5.240000247955322)
[2022-10-28 14:11:43.435935] INFO: Position: returning cash: 0.7472
[2022-10-28 14:11:43.664661] INFO: Performance: Simulated 39 trading days out of 39.
[2022-10-28 14:11:43.669151] INFO: Performance: first open: 2022-08-24 09:30:00+00:00
[2022-10-28 14:11:43.672499] INFO: Performance: last close: 2022-10-25 15:00:00+00:00
[2022-10-28 14:11:46.143194] INFO: moduleinvoker: backtest.v8 运行完成[15.141713s].
[2022-10-28 14:11:46.147190] INFO: moduleinvoker: trade.v4 运行完成[20.987591s].