更新:
有很多朋友私信问我Python学习有没有什么好的资料,我给大家找了几门不错的免费课,想学的可以看看。
《Python入门教程》Python入门教程--Python视频教程-编程语言-CSDN学院edu.csdn.net
《Python初级入门精讲》Python初级入门精讲--Python视频教程-编程语言-CSDN学院edu.csdn.net
《Python爬虫开发》Python爬虫开发--Python视频教程-编程语言-CSDN学院edu.csdn.net
《Python实战编程》Python实战编程--Python视频教程-编程语言-CSDN学院edu.csdn.net
《1小时掌握Python爬虫+高效学习法则》1小时掌握Python爬虫+高效学习法则--Python视频教程-编程语言-CSDN学院edu.csdn.net
原回答:
我最开始是在网上找实例跟着做的,后来慢慢练思路有了自己也可以写程序了。
比如这些,我觉得很适合新手练习。
实例一、十分钟学会写单股票均线量化策略
基于在Ricequant 量化平台的实现
1 确定框架:
[单股票均线策略] 的主要策略框架: 5 日均线高于 30 天均线,则全仓买入股票 5 日均线低于 30 天均线,则卖出所持股票
从我们日常交易的角度,一般交易者的行为可以拆分以下两部分:
1 选择标的(初始化):
在交易之前,我们通常会先选定要交易的股票池或者单个股票。
2 交易(每天盯盘)
我们会观察该股票的五日均线和 30 日均线,并进行比较 如果该股票的五日均线在 30 天均线以上,则全仓买入股票 如果该股票的五日均线在 30 天均线以下,则全仓卖出(空仓)。
那么程序中,我们是怎么做的呢?
先看看 Ricequant 平台中对应的代码框架会是怎么样的吧:
def init(context):#程序的初始化,预设股票池、设置参数和变量。 只运行一次
def handle(context, bar_dict): #从回测的开始日期至结束日期,根据选择的频率(日、分钟)循环运行
对照策略思路 及 Ricequant 代码框架,你会发现我们可以很轻松地把 两者结合起来
以上框架也是 Ricequant 平台的最基本也最主要的框架,也就是初始化
循环 - 根据选择的频率(日、分钟)循环运行
2 初始化:
选择标的:本策略的交易股票设定为 300059 ”东方财富“。
def init(context):
context.stock = "300059.XSHE" # 存入目标股票 [东方财富 ]
延伸阅读:
1 在 init 中实现程序的初始化,例如存入目标股票池,设置滑点、基准等参数以及设置其它变量。 context 是一个全局的容器,你可以通过它设置任何全局变量并初始化:如 context.stock 将会在后面代码所被调用到。
2 代码中 # 代表注释,作为代码说明,执行时会被跳过而不为程序所运行。
3 如何填写股票代码:你会发现策略代码中 股票代码后带有后缀,那么它们分别代表什么呢?
后缀为XSHE 代表在深交所上市交易的股票
XSHG 在上交所上市交易的股票
例子:300059.XSHE 为深交所上市的东方财富
600000.XSHG 为上交所上市的浦发银行
我们的代码编辑器还提供了非常便利的股票代码自动寻找和补全功能,在 Windows 中你可以用 ctrl+i , Mac 系统你可以用 cmd+i 激活证券代码自动补全功能。如下图: />
3 获取均价:
我们分别获取该股票 5 日和 30 日的均价
# 用法:变量 = bar_dict[股票代码].mavg(天数, frequency='day')
# 获取近五日股票收盘价均价,命名为 fast
fast = bar_dict[context.stock].mavg(5, frequency='day')
# 同上,获取近二十日的收盘价均价,命名为 slow :
slow = bar_dict[context.stock].mavg(30, frequency='day')
4 判断买卖条件:
获得均价数据之后,我们就可以进行一个判断决定是否买卖了:
if fast>slow:# 若快线在慢线之上则用所有现金买入该股票(买入操作)
elif fast
在判断之前,我们还漏了一步,那是什么呢?就是要知道我们有多少现金,那么在程序中是如何获得现金的呢?我们使用以下代码
# 用法:变量 = context.portfolio.cash
cash = context.portfolio.cash#取得当前的现金量,命名为 cash
延伸阅读: portfolio 中 包含所有的投资组合的信息,请参考文档 - Portfolio 对象
5 买入 /卖出:
在判定买卖的条件成立之后,我们会对股票进行买入或者卖出的操作:
#用法 order_value(股票代码,买卖金额) 金额为正则为买入,负数则为卖出
#将所有现金买入 300059 东方财富
order_value(context.stock, cash)
#用法: order_target_value(股票代码,目标持仓比例) 比例在 1 与 0 之间
#此处将持仓比例调整为 0 ,则等同于全部卖出
order_target_percent(context.stock, 0)
完整代码就是: />
6 策略回测 />
如代码没有问题,在数秒之后,我们就会拿到该策略的历史表现结果: />
我们可以看到回测详情中有精致的图表,详细的各项风险收益指标、以及持仓、落单等详情辅助你进一步了解你的策略的表现。
到这里,一个完整的从 [构建策略思路] 到 [策略代码编写] 到 [回测结果检验] 的流程就结束了。
7 从日回测到分钟回测:
在循环部分, handle 函数根据选择的频率(日、分钟)循环运行,在以上的日回测中, handle 内的代码会每日被触发一次
def handle(context, bar_dict):
如果是进行分钟回测或模拟实盘,那么这个 handle 里的代码就会被每分钟触发一次;
因此,我们的代码逻辑也势必要进行一定的改进,使得策略按照我们的逻辑正常地运行。
我们先把修改好的代码贴上来:
def init(context):
context.stock = "300059.XSHE"
# 每日开盘前运行一次,可以进行选股、设置参数等行为
def before_trading(context):
# 设定并重置 context.fired 的值为 0
context.fired = 0
#从回测的开始日期至结束日期,根据选择的频率(日、分钟)循环运行
def handle_bar(context, bar_dict):
# 判定今日是否有下过单,若未下单则进行下列代码的操作
if (context.fired == 0):
slow = bar_dict[context.stock].mavg(30, frequency='day')
fast = bar_dict[context.stock].mavg(5, frequency='day')
cash = context.portfolio.cash
if fast>slow:
order_value(context.stock, cash)
elif fast < slow:
order_target_percent(context.stock, 0)
# 设置 fired 等于 1 ,表示执行完毕
context.fired = 1
可以看到这里改动并不多,这里需要介绍到框架中常用到的函数 before_trading :
# 每日开盘前运行一次,可以进行选股、设置参数等行为
def before_trading(context):
我们在 before_trading 中设置一个变量命名为 fired ,赋值为 0
# 设定并重置 context.fired 的值为 0
context.fired = 0
由于 before_trading 是每天开盘前运行一次,所以 context.fired 会被每天重置为 0。在 handle 函数中,我们加入了判断,如 context.fired 为 0 ,则继续执行下面的代码,否则本次循环结束。
# 判定今日是否有下过单,若未下单则进行下列代码的操作
if (context.fired == 0):
并在执行完判断和买卖操作之后,设定 context.fired 的值等于 1 ,使得当日余下的分钟循环操作均被跳过。
# 设置 fired 等于 1 ,表示今天已下过单
context.fired = 1
在完成以上代码后,我们开始进行分钟回测吧: 在策略编辑页面右上方,选择从 2015 年 1 月 4 日至 2016 年 10 月 4 日,用资金 100 万元进行分钟回测吧,更新策略后点击运行回测 。
8 模拟交易:
模拟交易通过实时的分钟切片数据进行撮合,也就是 handle 函数会每分钟被触发一次循环。在开启你的策略的模拟交易之前,你必须要对它进行一次分钟回测,才可以开启模拟交易。 在上面分钟回测之后,你可以在策略回测详情页面点击 开启模拟交易。
9 开启微信通知,接收交易信号:
点击导航栏中的 [我的交易] ,可以在 [模拟交易] 一栏看到创建的模拟交易,如下图:
/>
点击右边的微信通知开关,将 OFF 调至 ON ,并按照指示扫描二维码,绑定微信,就能通过微信接收交易信号了。
当该策略进行买卖操作,你的微信会收到类似下图的信号提醒。微信推送的延迟非常小,使得你能根据信号进行及时的下单操作。
/>
实例二、Python爬取13个旅游城市,告诉你五一大家最爱去哪玩?
1.用到的Python模块
BeautifulSoup、requests、pymongo、pylab
2.方法
这里为了偷懒只爬取了前4页的景点信息,每页有15个景点。因为去哪儿并没有什么反爬措施,所以直接请求就可以了。
这里只是随机选择了13个热门城市:北京, 上海, 成都, 三亚, 广州, 重庆, 深圳, 西安, 杭州, 厦门, 武汉, 大连, 苏州。
并将爬取的数据存到了MongoDB数据库 。
爬虫部分完整代码如下 /> />
效果图如下: />
有了数据,我们就可以分析出自己想要的东西了
最受欢迎的15个景区
/>
由图可以看出,在选择的13个城市中,最热门的景区为上海的迪士尼乐园 />
案例均来源于网络,希望对你有用