如何使用行名稱移除 R 資料框中的行?
有許多子集 R 資料框的方法,有時我們需要透過移除行來實現。通常,我們會使用行索引號移除行,但我們也可以使用行名稱來實現。這可以透過將需移除的行名稱儲存在向量中,然後使用方括號進行子集來移除,如下例所示。
示例
考慮以下資料框
> x<-rnorm(20,1,0.04) > y<-rnorm(20,100,4) > row.names(df)<-LETTERS[1:20] > df
輸出
x y A 0.9454799 96.62077 B 0.9642909 101.54903 C 1.0294169 97.17593 D 0.9877072 98.98962 E 1.0182932 92.32761 F 1.0351041 103.04182 G 0.9613700 90.65195 H 1.0240703 99.63975 I 0.9424871 97.11730 J 0.9876748 108.07684 K 1.0652311 102.14823 L 1.0196251 93.51378 M 0.9752639 100.57394 N 0.9890722 101.37151 O 0.9873279 100.37910 P 0.9564027 96.94806 Q 0.9456446 103.40934 R 0.9617322 94.89198 S 0.9956141 86.43256 T 1.0253881 101.52844
製作需要移除的行名稱的向量
示例
> row_names_df_to_remove<-c("A","B","C","D","E")
移除指定的行名稱
示例
> df[!(row.names(df) %in% row_names_df_to_remove),]
輸出
x y F 1.0351041 103.04182 G 0.9613700 90.65195 H 1.0240703 99.63975 I 0.9424871 97.11730 J 0.9876748 108.07684 K 1.0652311 102.14823 L 1.0196251 93.51378 M 0.9752639 100.57394 N 0.9890722 101.37151 O 0.9873279 100.37910 P 0.9564027 96.94806 Q 0.9456446 103.40934 R 0.9617322 94.89198 S 0.9956141 86.43256 T 1.0253881 101.52844
我們來看另一個示例
示例
> set.seed(3247) > x1<-rpois(20,1) > x2<-rpois(20,5) > df1<-data.frame(x1,x2) > df1
輸出
x1 x2 1 3 5 2 1 8 3 3 3 4 0 6 5 2 2 6 1 6 7 0 1 8 2 2 9 1 3 10 0 4 11 3 1 12 0 4 13 0 5 14 1 4 15 1 3 16 1 7 17 2 3 18 0 0 19 1 3 20 0 5
示例
> row.names.df1<-c(1:5) > df1[!(row.names(df1) %in% row.names.df1),]
輸出
x1 x2 6 1 6 7 0 1 8 2 2 9 1 3 10 0 4 11 3 1 12 0 4 13 0 5 14 1 4 15 1 3 16 1 7 17 2 3 18 0 0 19 1 3 20 0 5
廣告