京公网安备 11010802034615号
经营许可证编号:京B2-20210330
R语言建立时间序列的两个函数
金融数据必须是时间序列,才可进行经济统计分析。建立时间序列,必须有日期作为数据框的一列。R语言建立时间序列的两个函数是ts()和as.xts()。
1.ts()
library(stats) #stats软件包是R语言环境启动的7个软件包
ts(gm,frequency=12,start=c(1975,1))
这个命令表示:
(1) frequency=12表明时间单位为年,而且在每一个时间单位中有12个均匀间隔的观察值。
因此gm是月数据,在金融数据中,常用的有月收益率数据。
(2) start=c(1975,1)表示开始时间为1975年1月。
(3) gm应是列数据,而不能是多列金融数据。而且gm在数据框中选择出来时,应有日期在同一个数据框中。
frequency和start是R中ts()函数产生时间序列对象需要的两个基本参数。frequency的用法,
(a)frequency=4表明时间单位是年,每一个时间单位中有4个季节观察值。
(b)frequency=365表明时间单位是年,每一个时间单位中有365个日期观察值。
若样本容量T<365,则可用frequency=T表示。
start的用法。
(a)若ts(gm,frequency=365,start=c(2014,1,1))建立时间序列。
但是,若用 ts(gm,frequency=365,start=c(2014,1,1),end(2014,12,31))结果将不同。
(b)若用ts(gm,frequency=1,start=c(2014,1,1))则,创建的时间序列start和end不同,将1年的时间单位用1天表示。
这个用法一般是gm只有一年的数据,对此年的数据进行以天为单位的经济统计。
然而金融数据大多数并不是以365个数据为一年的数据,比如股市一年的有效数据一般在240多天,因此frequence的选择应该与一年的实际数据为准。
完整的函数表示:
ts(data = NA, start = 1, end = numeric(0), frequency = 1, deltat = 1,
ts.eps = getOption("ts.eps"), class = , names = )
详细信息可见R语言系统
>?ts
e.g. 参数class
|
|
class to be given to the result, or none ifNULLor"none". The default is"ts"for a single series,c("mts", "ts", "matrix")for multiple series. |
2.as.xts()
as.xts()与ts()不同,要求行名是日期。因此数据框中的日期必须赋值到行名,
而且删除日期所在的列。
eg1. as.xts()建立时间序列的主要命令
da=read.table("m-gm3dxjsh2016.txt",header=T)
gm2016=da[,1:2] #da[1]是日期,da[2]是金融数据
rownames(gm2016)=gm2016[,1] #将日期赋值到行名,注意不能用gm2016[1],否则长度不同
gm=gm2016[-1] # 去掉第一列
gm1=as.xts(gm[,1]) # 建立金融数据的时间序列,实际上这个语句并能运行,原因见eg2.
将日期赋值到行名的编程方法有很多,第二个程序的数据文件不同。
eg2.as.xts()建立时间序列的完整程序
> da=read.table("D:/programsdata/financialCapital/m-gm3dx2016.txt",head=T)
>head(da)
date gm vw ew sp
1 19750131 0.252033 0.141600 0.299260 0.122812
2 19750228 0.028571 0.058411 0.053918 0.059886
3 19750331 0.054487 0.030191 0.081497 0.021694
4 19750430 0.045593 0.046497 0.031093 0.047265
5 19750530 0.037209 0.055140 0.072876 0.044101
6 19750630 0.107955 0.051473 0.071792 0.044323
>gm2016=da[,1:2] #gm2016是数据框
>head(gm2016)
date gm
1 19750131 0.252033
2 19750228 0.028571
3 19750331 0.054487
4 19750430 0.045593
5 19750530 0.037209
6 19750630 0.107955
> dim(gm2016)
[1] 408 2
> str(gm2016) #成员date是int型
'data.frame': 408 obs. of 2 variables:
$ date: int 19750131 19750228 19750331 19750430 19750530 19750630 19750731 19750829 19750930 19751031 ...
$ gm : num 0.252 0.0286 0.0545 0.0456 0.0372 ...
> d=as.character(gm2016[,1]) #将int型日期转换成Date型
> d1=as.Date(d,format="%Y%m%d")
> head(d1)
[1] "1975-01-31" "1975-02-28" "1975-03-31" "1975-04-30" "1975-05-30"
[6] "1975-06-30"
> class(d1)
[1] "Date"
> gm=gm2016[,2,drop=FALSE] #获得数据框gm2016的第二列,drop=FALSE防止出现向量
> class(gm) #gm是数据框
[1] "data.frame"
> head(gm)
gm
1 0.252033
2 0.028571
3 0.054487
4 0.045593
5 0.037209
6 0.107955
> str(gm) #成员gm的类型是num数值型
'data.frame': 408 obs. of 1 variable:
$ gm: num 0.252 0.0286 0.0545 0.0456 0.0372 ...
> rownames(gm)=d1 #gm的行名是R语言标准时间表示
> head(gm)
gm
1975-01-31 0.252033 #注意19750131是不允许的
1975-02-28 0.028571
1975-03-31 0.054487
1975-04-30 0.045593
1975-05-30 0.037209
1975-06-30 0.107955
>library(xts)
>gm2=as.xts(gm)
比较
ts()和as.xts()两个函数产生的时间序列的plot图略有不同。然而acf图和pacf图则相同。
nm1=as.xts(data1)
nm2=ts(data1,frequency=365,start=c(2014,1,1),end=c(2014,12,31))
acf(nm1,lag=20)
pacf(nm1,lag=20)
acf(nm2,lag=20)
pacf(nm2,lag=20)
plot(nm1)
plot(nm2)
图1 acf和pacf图
图2 两个函数产生的时间序列的plot图
可以看到plot图中,ts()产生的时间序列更为精细,而as.xts()的时间序列则略微粗糙。
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
在大数据技术飞速迭代、数字营销竞争日趋激烈的今天,“精准触达、高效转化、成本可控”已成为企业营销的核心诉求。传统广告投放 ...
2026-04-24在游戏行业竞争白热化的当下,用户流失已成为制约游戏生命周期、影响营收增长的核心痛点。据行业报告显示,2024年移动游戏平均次 ...
2026-04-24 很多业务负责人开会常说“我们要数据驱动”,最后却变成“看哪张报表数据多就用哪个”,往往因为缺乏一套结构性的方法去搭建 ...
2026-04-24在Power BI数据可视化分析中,切片器是连接用户与数据的核心交互工具,其核心价值在于帮助使用者快速筛选目标数据、聚焦分析重点 ...
2026-04-23以数为据,以析促优——数据分析结果指导临床技术改进的实践路径 临床技术是医疗服务的核心载体,其水平直接决定患者诊疗效果、 ...
2026-04-23很多数据分析师每天盯着GMV、DAU、转化率,但当被问到“哪些指标是所有企业都需要的”“哪些指标是因行业而异的”“北极星指标和 ...
2026-04-23近日,由 CDA 数据科学研究院重磅发布的《2026 全球数智化人才指数报告》,被中国教育科学研究院官方账号正式收录, ...
2026-04-22在数字化时代,客户每一次点击、浏览、下单、咨询等行为,都在传递其潜在需求与决策倾向——这些按时间顺序串联的行为轨迹,构成 ...
2026-04-22数据是数据分析、建模与业务决策的核心基石,而“数据清洗”作为数据预处理的核心环节,是打通数据从“原始杂乱”到“干净可用” ...
2026-04-22 很多数据分析师每天盯着GMV、转化率、DAU等数字看,但当被问到“什么是指标”“指标和维度有什么区别”“如何搭建一套完整的 ...
2026-04-22在数据分析与业务决策中,数据并非静止不变的数值,而是始终处于动态波动之中——股市收盘价的每日涨跌、企业月度销售额的起伏、 ...
2026-04-21在数据分析领域,当研究涉及多个自变量与多个因变量之间的复杂关联时,多变量一般线性分析(Multivariate General Linear Analys ...
2026-04-21很多数据分析师精通描述性统计,能熟练计算均值、中位数、标准差,但当被问到“用500个样本如何推断10万用户的真实满意度”“这 ...
2026-04-21在数据处理与分析的全流程中,日期数据是贯穿业务场景的核心维度之一——无论是业务报表统计、用户行为追踪,还是风控规则落地、 ...
2026-04-20在机器学习建模全流程中,特征工程是连接原始数据与模型效果的关键环节,而特征重要性分析则是特征工程的“灵魂”——它不仅能帮 ...
2026-04-20很多数据分析师沉迷于复杂的机器学习算法,却忽略了数据分析最基础也最核心的能力——描述性统计。事实上,80%的商业分析问题, ...
2026-04-20在数字化时代,数据已成为企业决策的核心驱动力,数据分析与数据挖掘作为解锁数据价值的关键手段,广泛应用于互联网、金融、医疗 ...
2026-04-17在数据处理、后端开发、报表生成与自动化脚本中,将 SQL 查询结果转换为字符串是一项高频且实用的操作。无论是拼接多行数据为逗 ...
2026-04-17面对一份上万行的销售明细表,要快速回答“哪个地区卖得最好”“哪款产品增长最快”“不同客户类型的购买力如何”——这些看似复 ...
2026-04-17数据分析师一天的工作,80% 的时间围绕表格结构数据展开。从一张销售明细表到一份完整的分析报告,表格结构数据贯穿始终。但你真 ...
2026-04-16