python实现趋势预测,仅供自己复习使用

import numpy as np
import datetime as dt
import matplotlib.pyplot as mp
import matplotlib.dates as md
import pandas as pd


def dmy2wday(dmy):
    dmy = str(dmy, encoding='utf-8')
    date = dt.datetime.strptime(dmy, '%d-%m-%Y').date()
    ymd = date.strftime('%Y-%m-%d')
    return ymd

dates, closing_prices =\
    np.loadtxt('C:/Users/Administrator/Desktop/asd/DS/data/aapl.csv',
               delimiter=',', usecols=(1, 6), unpack=True,
               dtype=np.dtype('M8[D],f8'),
               converters={1: dmy2wday})


n = 10
pred_prices = np.zeros(closing_prices.size - 2 * n + 1)
for i in range(pred_prices.size):
    a = np.zeros((n, n))
    for j in range(n):
        a[j, ] = closing_prices[i + j:i + j + n]
    b = closing_prices[i + n:i + n * 2]
    x = np.linalg.lstsq(a, b)[0]
    pred_prices[i] = b.dot(x)
    print(pred_prices)

mp.figure('Stock Price Prediction', facecolor='lightgray')
mp.title('Stock Price Prediction', fontsize=20)
mp.xlabel('Date', fontsize=14)
mp.ylabel('price', fontsize=14)
ax = mp.gca()
ax.xaxis.set_major_locator(
    md.WeekdayLocator(byweekday=md.MO))

ax.xaxis.set_major_formatter(
    md.DateFormatter('%d %b %Y'))
mp.tick_params(labelsize=10)
mp.grid(linestyle=':')

dates = dates.astype(md.datetime.datetime)
mp.plot(dates, closing_prices, 'o-', c='lightgray', label='Closing Price')

dates = np.append(dates, dates[-1] + pd.tseries.offsets.BDay())
mp.plot(dates[n * 2:], pred_prices, 'o-',
        c='orangered', label='Prediction Price')

mp.legend()
mp.gcf().autofmt_xdate()
mp.show()
 

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值