[英]R how to selectively sort a data frame?
我在R中有以下示例數據框。
item index ptr
A 1 0.40
B 2 NA
C 3 0.30
D 4 0.35
E 5 0.44
F 6 NA
它已經基於column = index
排序。 現在,我想通過列ptr
對其進行排序,但是保留ptr
= NA
完整的行的位置。 所以我期望的輸出是:
item index ptr
C 3 0.30
B 2 NA
D 4 0.35
A 1 0.40
E 5 0.44
F 6 NA
常規df = df[order(ptr),]
不起作用。 有任何想法嗎? 非常感謝提前。
嘗試這個:
> df
item index ptr
1 A 1 0.40
2 B 2 NA
3 C 3 0.30
4 D 4 0.35
5 E 5 0.44
6 F 6 NA
> df[!is.na(df$ptr), ] <- df[order(df$ptr, na.last = NA), ]
> df
item index ptr
1 C 3 0.30
2 B 2 NA
3 D 4 0.35
4 A 1 0.40
5 E 5 0.44
6 F 6 NA
ptr.na <- is.na(df$ptr)
order.idx <- seq(length=nrow(df))
ptr.idx <- which(!ptr.na)
order.idx[!ptr.na] <- ptr.idx[order(df[ptr.idx,"ptr"])]
df[order.idx,]
給
> df[order.idx,]
item index ptr
3 C 3 0.30
2 B 2 NA
4 D 4 0.35
1 A 1 0.40
5 E 5 0.44
6 F 6 NA
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.