83行代码


使用SARIMAX进行时间序列预测。


#!/usr/bin/env python
#-*-coding:utf-8-*-

#******************************************************************************
#****************Description:Time Series prediction using SARIMAX
#****************Author:Duan Tingyin
#****************Date:2018.02.14
#**************************************************

import pandas as pd
import matplotlib.pyplot as plt
import datetime
from statsmodels.tsa.api  import SARIMAX

datapath = '../data/'
train_df = pd.read_csv(datapath+'[new] yancheng_train_20171226.csv')
testA_df = pd.read_csv(datapath+'yancheng_testA_20171225.csv')
testB_df = pd.read_csv(datapath+'yancheng_testB_20180224.csv')


train_class = train_df.groupby(['sale_date','class_id'])['sale_quantity'].sum().to_frame().reset_index()
train_class.head()


def plt_class(data,x,y,class_id):
    this_class_id=data[data.class_id == class_id]
    plt.scatter(x=this_class_id[x],y=this_class_id[y])


def trans_date(x):
    str_x=str(x)
    year=int(str_x[:4])
    month=int(str_x[4:])
    return datetime.date(year,month,1)


train_class['_sale_date']=train_class['sale_date'].apply(trans_date)
testA_df['_sale_date']=testA_df['predict_date'].apply(trans_date)
testB_df['_sale_date']=testB_df['predict_date'].apply(trans_date)
#print(train_class.head(),testA_df.head(),testB_df.head())


s="predict_date,class_id,predict_quantity"
ex=[]
f=open("../data/yancheng_testA_20171225.csv","r")
for line in f.readlines():

    if "date" in line:
       continue

    class_id=int(line.split(",")[1])
    this_class_id=train_class[train_class['class_id']==class_id][['_sale_date','sale_quantity']]
    if class_id==653436:
        print(this_class_id._sale_date)
    #indexed_this_class_id = this_class_id.set_index(this_class_id['_sale_date'])
    indexed_this_class_id=this_class_id.set_index(pd.date_range(end='2017-11',periods=len(this_class_id['_sale_date']),freq='M'))
    print(this_class_id['_sale_date'],pd.date_range(end='2017-11',periods=len(this_class_id['_sale_date']),freq='M'))

    res=0
    try:
        fit1=SARIMAX(indexed_this_class_id.sale_quantity,verbose=False).fit()
        pre=fit1.get_forecast().conf_int()
        res=(int(round((pre['lower sale_quantity'] + pre['upper sale_quantity'])*0.5)))
    except Exception as e:
        print(e)
        ex.append(class_id)
        plt_class(train_class,'sale_date','sale_quantity',class_id)
        res=int(this_class_id['sale_quantity'].iloc[-1])
        this_class_id.to_csv('EXCEPTION'+str(class_id) +".csv",header=True,index=False,float_format='%.0f')

    s+="\n"
    s+="201711"+ ","+str(class_id) + "," +str(res)
f.close()

s+="\n"
train_class[['sale_date','class_id','sale_quantity']].to_csv('train_class.csv',header=True,index=False,float_format='%.0f')

fw=open("201711.csv","w")
fw.write(s)
fw.close()


print(ex)

优秀的个人博客,低调大师

微信关注我们

原文链接:https://yq.aliyun.com/articles/590794

转载内容版权归作者及来源网站所有!

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

相关文章

发表评论

资源下载

更多资源
优质分享Android(本站安卓app)

优质分享Android(本站安卓app)

近一个月的开发和优化,本站点的第一个app全新上线。该app采用极致压缩,本体才4.36MB。系统里面做了大量数据访问、缓存优化。方便用户在手机上查看文章。后续会推出HarmonyOS的适配版本。

Mario,低调大师唯一一个Java游戏作品

Mario,低调大师唯一一个Java游戏作品

马里奥是站在游戏界顶峰的超人气多面角色。马里奥靠吃蘑菇成长,特征是大鼻子、头戴帽子、身穿背带裤,还留着胡子。与他的双胞胎兄弟路易基一起,长年担任任天堂的招牌角色。

Eclipse(集成开发环境)

Eclipse(集成开发环境)

Eclipse 是一个开放源代码的、基于Java的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。幸运的是,Eclipse 附带了一个标准的插件集,包括Java开发工具(Java Development Kit,JDK)。

Sublime Text 一个代码编辑器

Sublime Text 一个代码编辑器

Sublime Text具有漂亮的用户界面和强大的功能,例如代码缩略图,Python的插件,代码段等。还可自定义键绑定,菜单和工具栏。Sublime Text 的主要功能包括:拼写检查,书签,完整的 Python API , Goto 功能,即时项目切换,多选择,多窗口等等。Sublime Text 是一个跨平台的编辑器,同时支持Windows、Linux、Mac OS X等操作系统。