2

我想从自动创建一次并被使用的 row.names 中编辑掉一些split信息cut2。请参见以下代码:

#Mock data
date_time <- as.factor(c('8/24/07 17:30','8/24/07 18:00','8/24/07 18:30',
                        '8/24/07 19:00','8/24/07 19:30','8/24/07 20:00',
                        '8/24/07 20:30','8/24/07 21:00','8/24/07 21:30',
                        '8/24/07 22:00','8/24/07 22:30','8/24/07 23:00',
                        '8/24/07 23:30','8/25/07 00:00','8/25/07 00:30'))
U. <- as.numeric(c('0.2355','0.2602','0.2039','0.2571','0.1419','0.0778','0.3557',
                 '0.3065','0.1559','0.0943','0.1519','0.1498','0.1574','0.1929'
                 ,'0.1407'))

#Mock data frame
test_data <- data.frame(date_time,U.)


#To use cut2
library(Hmisc)

#Splitting the data into categories
sub_data <- split(test_data,cut2(test_data$U.,c(0,0.1,0.2)))
new_data <- do.call("rbind",sub_data)
test_data <- new_data

您将看到“test_data”将有一个额外的列“row.names”,其中包含“[0.000,0.100).6”、“[0.000,0.100).10”等值。

如何删除“[0.000,0.100)”并保留“。”后面的数字 例如 6 和 10 以便我以后可以通过它们的原始行号引用这些行?

还有其他更好的方法吗?

4

3 回答 3

1

您可以使用正则表达式 (Regex),如下所示:

rownames(test_data) = gsub(".*[]\\)]\\.", "", rownames(test_data))

如果您不熟悉正则表达式,这很神秘,但它基本上说匹配任何字符序列 ( .*),后跟大括号或圆括号 ( []\\)]),然后是句点 ( \\.),然后将其全部删除。

双反斜杠是“转义符”,表示双反斜杠后面的字符应按字面意思解释,而不是按其特殊的正则表达式含义(例如,.表示“匹配任何单个字符”,但\\.表示“这实际上只是一个句点”) .

于 2014-06-25T22:45:01.540 回答
1

只是为了好玩,您也可以使用regmatches

> Names <- rownames(test_data)
> ( rownames(test_data) <- regmatches(Names, regexpr("[0-9]+$", Names))  )
 [1] "6"  "10" "5"  "9"  "11" "12" "13" "14" "15" "1"  "2"  "3"  "4"  "7"  "8" 
于 2014-06-25T22:54:21.033 回答
1

您还可以将 sub_data 的名称设置为 NULL。

names(sub_data) <- NULL     
test_data <- do.call('rbind', sub_data)
row.names(test_data)
#[1] "6"  "10" "5"  "9"  "11" "12" "13" "14" "15" "1"  "2"  "3"  "4"  "7"  "8" 
于 2014-06-26T04:03:40.883 回答