我可以帮你创建一个基于5年步长的新分组变量,与你的数据相关的IT技术内容。请看下面的示例:
假设你有以下数据:
group <- c(rep("A", 7), rep("B", 10))
year <- c(2008:2014, 2005:2014)
dat <- data.frame(group, year)
group year
1 A 2008
2 A 2009
3 A 2010
4 A 2011
5 A 2012
6 A 2013
7 A 2014
8 B 2005
9 B 2006
10 B 2007
11 B 2008
12 B 2009
13 B 2010
14 B 2011
15 B 2012
16 B 2013
17 B 2014
到这里:
> dat
group year period
1 A 2008 2005_2009
2 A 2009 2005_2009
3 A 2010 2010_2014
4 A 2011 2010_2014
5 A 2012 2010_2014
6 A 2013 2010_2014
7 A 2014 2010_2014
8 B 2005 2005_2009
9 B 2006 2005_2009
10 B 2007 2005_2009
11 B 2008 2005_2009
12 B 2009 2005_2009
13 B 2010 2010_2014
14 B 2011 2010_2014
15 B 2012 2010_2014
16 B 2013 2010_2014
17 B 2014 2010_2014
我想我可以使用cut(dat$year, breaks = ??)
,但我不知道如何设置断点。
paste(min <- floor(dat$year/10)*10, min+9,sep = "_")
。很好的解决方案! - fdetschfloor
,而是使用整数除法%/%
。例如(dat$year%/%5)*5
。 - nicola