写量化策略时常用的技巧

本文介绍了在编写量化策略时如何利用Windpy接口创建三维Panel数据。通过先分后合的方法,先处理各个因子的历史序列,然后通过内外层循环构造三维数据。此外,还讨论了Wind API的数据获取限制及其对策略编写的影响,推荐了聚宽作为替代方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.善用panel保存数据

说明:pandas有三种数据结构,分别是Series(一维),DataFrame(二维),panel(三维)

例子:沪深300成分股所有股票[stock list]在某些特征指标如成交量、收盘价[indicator list]上的某时间区间内的历史序列[time series],
[stock list] * [indicator list] * [time series]=3维

Q:如何通过Windpy接口来形成我们的三维面板数据呢?
A:按个股循环,获取每只股票的序列数据(二维);再把300只个股合并成三维。

例代码1:获取面板原始数据(daily),后期再在这张大的面板数据上计算月度的情况,再排序形成组合。再形成一个新的面板。【思路:总-分-总】

ps1:缺点就是从总表中拆开按每个因子形成月度收益再concat合并,这个过程很麻烦,不如一开始就按因子分开处理好,再合并形成面板数据。

ps2:wind API每天12000条左右的记录限制,意味着300只股票,每天只能他爸爸的获取30天的数据,10年的数据(120个月)得花120天来下载,这很坑啊。。。肯定是要另外想办法的,平时写策略主要目的是训练思路和练手,对数据质量要求不太高,目前看来,聚宽是最好的选择,策略编写平台类似jupyter notebook,也支持python的所有package。

import pandas as pd
import copy
from WindPy import w
import datetime
w.start() 

## 函数getAsharePanels(),获取A股历史面板数据
def getAsharePanels(stockcodes,start_date,end_date):

    append_data=pd.DataFrame(columns=['trade_date','stock_code','open','high','low','close','volume']) #产生一个辅助数据集,帮助后面循环时汇总
    individual_data=pd.DataFrame() #存放个股交易信息的数据集
    result={} #result是一个三维的字典
    for individual_stockcode in stockcodes:

        # 依次生成个股数据集(变量包括:日期、代码、开盘价、最高价、最低价、收盘价、成交量)
        stock=w.wsd(individual_stockcode, "trade_code,open,high,low,close,volume",start_date,end_date)
        individual_data['trade_date']=stock.Times
        individual_data['stock_code']=stock.Data[0]
        individual_data['open']=stock.Data[1]
        individual_data['high'
### 关于期货量化策略服务或学习教程 #### 一、关于期货量化策略的学习资源 对于初学者来说,了解并掌握期货量化的基础知识是非常重要的。目前市面上有许多优秀的学习资料可以帮助入门者快速上手。 1. **书籍推荐** - 推荐《Python金融大数据分析》这本书籍[^3],它涵盖了从基础的数据处理到复杂的模型构建等内容,非常适合希望利用编程实现量化交易的人群。 - 另外,《量化投资——以MATLAB为工具》也是一本不错的教材[^4],尽管其主要基于MATLAB环境开发案例,但对于理解算法逻辑同样适用。 2. **在线课程文档** - Coursera 和 edX 平台上均有开设有关金融市场建模以及程序化交易的相关课程[^5]。通过这些结构化的教学视频加上实践作业能够有效提升个人技能水平。 - 官方文档也是不可忽视的重要参考资料之一。例如 Pandas 的官方指南提供了详尽的操作说明,这对于数据分析环节至关重要[^6]。 3. **社区交流** 加入一些专注于量化交易技术讨论的论坛如 Quantopian (现已关闭但仍有存档可用)[^7], 或国内较为活跃的技术博客园地,则能获得更多实战经验和技巧分享。 #### 二、针对具体需求的服务选项 如果暂无法投入大量精力自行研发完整的解决方案,也可以考虑寻求外部支持: 1. **第三方服务商** 市场上确实存在提供定制化服务的企业和个人开发者团队愿意承接此类项目工作。不过需要注意甄别资质信誉良好的合作伙伴以免造成不必要的损失。可以通过知乎专栏搜索关键词找到部分评价较高的作者联系洽谈合作事宜[^8]。 2. **开源项目改造** 利用现有的成熟框架稍作调整即可满足个性化诉求。比如 Zipline 是一个广泛应用于回测系统的 Python 库[^9];还有前述提到过的 MetaTrader 提供了丰富的API接口便于接入自定义功能模块[^10]。 ```python from zipline.api import order_target, record, symbol, set_benchmark import pandas as pd def initialize(context): context.i = 0 context.asset = symbol('AAPL') set_benchmark(symbol('SPY')) def handle_data(context,data): ma1 = data.history(context.asset,'price',bar_count=10,frequency="1d").mean() ma2 = data.history(context.asset,'price',bar_count=30,frequency="1d").mean() if ma1 > ma2: order_target(context.asset,int(100)) elif ma1 < ma2: order_target(context.asset,-int(100)) record(AAPL=data.current(context.asset,'price')) ``` 以上代码片段展示了如何使用Zipline库创建简单的移动平均线交叉信号驱动买卖决策的过程。 ---
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值