多因子 市值+roe

# 导入函数库
import jqdata 




# 策略初始化
def initialize(context):
    g.security = get_index_stocks('000002.XSHG')#股票池
    set_option('use_real_price',True)#价格前复权
    set_benchmark('000002.XSHG')
    set_order_cost(OrderCost(open_tax=0,close_tax=0.001, open_commission=0.0003, close_commission=0.0003,min_commission=5), type='stock')
    g.q=query(valuation,indicator).filter(valuation.code.in_(g.security))
    g.N=20
    run_monthly(handle,1)


def handle(context):
    df=get_fundamentals(g.q)[['code','market_cap','roe']]#花式索引
    df['market_cap']=(df['market_cap']-df['market_cap'].min())/(df['market_cap'].max()-df['market_cap'].min())
    df['roe']=(df['roe']-df['roe'].min())/(df['roe'].max()-df['roe'].min())
    df['score']=df['roe']-df['market_cap']
    df=df.sort_values('score').iloc[-g.N:,:]
    to_hold=df['code'].values
    for stock in context.portfolio.positions:
        if stock not in to_hold:
            order_target(stock,0)
    to_buy=[stock for stock in to_hold if stock not in context.portfolio.positions]
    if len(to_buy) >0:
        cash_per_stock = context.portfolio.available_cash/len(to_buy) 
        for stock in to_buy:
            order_value(stock,cash_per_stock)

回测:

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值