经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » Python » 查看文章
量化投资-数据挖掘技术与实践
来源:cnblogs  作者:ambrose  时间:2019/10/8 9:09:07  对本文有异议

      定义:量化投资就是利用数学、信息学、统计学等领域的技术对投资对象进行量化分析和优化,从而进行精确投资的行为

  1. 特点:

    1.    基于市场是非有效的或弱有效的基础。
    2.    纪律性:绝对相信模型。
    3.    系统性:多层次、多角度、多数据。
    4.    妥善运用套利的思想。找估值洼地。低估买,高估卖。
    5.    靠概率取胜。
  2. 核心----量化模型

    1.   多因子选股模型:打分法、回归法
    2.   SVM择时模型

 

 

以上基础知识为博客申请以前所学,每日分享一点。

以下内容为今日所学:

  首先,我使用了python作为我的数据分析语言。这里简单说一下我的理由,

  1.  虽然我的参考书《量化投资--数据挖掘技术与实践》是基于matlab,但是matlab虽然相比于python有一些作图上的优势,但常用的基本数据分析能力二者是相差不大的,而且python语法简单易懂。
  2.     python使用人数是多余matlab的。这里不要去特立独行,使用的人多代表它的错误更少,功能也更齐全。
  3.    python节省了我的时间成本,matlab我需要从头了解。

      所以我基于python,今天主要分享一些获取数据的方法:

  python这边有许多接口都可以获得金融相关数据,当然其他数据应该也有,墨默并没有去了解他们。

  这些股市相关数据的接口封装在pandas内部,有的朋友们可能了解过,之前是在pandas.io.data里面封装的,但是现在早已经换地方了,再次通过pandas.io.data导入会报错。

  现在我们可以在 pandas_datareader.data 导入:

  1. 1 import pandas_datareader.data as web

      在这里我们以在雅虎中读取数据为例:

 代码十分简单:

  1. 1 start = datetime.datetime(2019,8,1) #开始时间
  2. 2 end = datetime.date.today() #结束时间
  3. 3
  4. 4 apple = web.DataReader("AAPL","yahoo",start,end) #在雅虎获取苹果公司(AAPL)
  5. 5 #2019年8月1日以来的数据
  6. 6 type(apple) #查看数据类型:pandas.core.frame.DataFrame
  7. 7 apple.head() #打印前5行代码
  8. 8
  9. 9 apple.to_csv("url/apple.csv") #将数据存储到名为apple 的csv文件

运行结果:

                                                          

 

 

apple.csv:

                                                                       

 

 

 对于数据分析而言可视化是必不可少的,毕竟我们在数据预处理阶段不能拿着一张海量数据的表去看那一条数据有问题……

我简单的做了一条折线图:

  1. 1 import matplotlib.pyplot as pl
  2. 2 %pylab inline
  3. 3
  4. 4 pylab.rcParams['figure.figsize'] = (15,9) #定义画布大小
  5. 5 apple.plot(grid = True) #

 

                                                                

 

 

 

 

除了雅虎之外我们的python还可以通过tushare获取数据

  Tushare是一个免费、开源的python财经数据接口包。主要实现对股票等金融数据从数据采集清洗加工 到 数据存储的过程,能够为金融分析人员提供快速、整洁、和多样的便于分析的数据,为他们在数据获取方面极大地减轻工作量,使他们更加专注于策略和模型的研究与实现上。考虑到Python pandas包在金融量化分析中体现出的优势,Tushare返回的绝大部分的数据格式都是pandas DataFrame类型,非常便于用pandas/NumPy/Matplotlib进行数据分析和可视化。 

 

  1. 1 import tushare as ts
  2. 2 import matplotlib.pyplot as plt
  3. 3 import mpl_finance as mpf
  4. 4 import numpy as np
  5. 5
  6. 6 data = ts.get_k_data('600519', ktype='D', autype='qfq', start='2017-09-17', end='') #数据获取
  7. 7
  8. 8 prices = data[['open', 'high', 'low', 'close']]
  9. 9 dates = data['date']
  10. 10
  11. 11 candleData = np.column_stack([list(range(len(dates))), prices])
  12. 12
  13. 13 fig = plt.figure(figsize=(10, 6)) #画布
  14. 14 ax = fig.add_axes([0.1, 0.3, 0.8, 0.6])
  15. 15
  16. 16 mpf.candlestick_ohlc(ax, candleData, width=0.5, colorup='r', colordown='b')
  17. 17
  18. 18 plt.show()#展示
View Code

运行结果:

                                                                

 

 

 

今天的分享暂且到这里,明天持续更新!

原文链接:http://www.cnblogs.com/ambdyx/p/11625071.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号