如何删除数据框中rownames的前n个字符? [R

时间:2015-10-11 17:33:41

标签: r rowname

我有一个如下所示的数据框:

                    date_tmp  efficiency        smb      rmrf      hml   rmw      cma    Returns
2010-11-04.Stock1 2010-11-04  0.4469618 0.87430339 0.7337814 0.00000000   0 0.60769928 1.245834
2010-11-04.Stock2 2010-11-04  0.6608003 0.65057967 2.2088113 0.00000000   0 0.10672836 1.659817
2010-11-04.Stock3 2010-11-04  0.3878181 0.88259984 0.2530008 0.04665325   0 1.38739047 1.388948
2010-11-04.Stock4 2010-11-04  0.4781154 0.93226537 0.0000000 0.16319179   0 1.43025290 1.331511
2010-11-04.Stock5 2010-11-04  0.4809276 0.56507215 1.9185010 0.00000000   0 0.09270075 1.441663
2010-11-04.Stock6 2010-11-04  0.4619094 0.06452728 1.8513120 0.00000000   0 0.40841138 1.251019

第一列显示行名称。

我需要的是删除所有行上的日期部分,例如(“Stock1”而不是“2010-11-04.Stock1”

我基本上需要这个函数的反转,它保留前n个字符而不是删除它们。

x <- "some text in a string"

substrRight <- function(x, n){
  substr(x, 1, n)
}

substrRight(x, 4)
[1] "some"

1 个答案:

答案 0 :(得分:0)

如果日期部分是您要删除的内容,您可能需要考虑使用正则表达式,例如

foo = function(x){
    return(gsub(".+\\.","",x))
}

如果你做foo(&#34; 2010-11-04.Stock1&#34;)将返回你&#34; Stock1&#34;