2014-12-02 1 views
5

Hier ist der Code auf Spalte v2 auf Rang basiert:Wie reihen Sie Zeilen in R in zwei Spalten auf einmal ein?

x <- data.frame(v1 = c(2,1,1,2), v2 = c(1,1,3,2)) 
x$rank1 <- rank(x$v2, ties.method='first') 

Aber ich will wirklich basierend auf Rang sowohl auf v2 und/dann v1, da es Verbindungen in v2. Wie kann ich das ohne RPostgreSQL tun?

Antwort

1

Wie wäre:

within(x, rank2 <- rank(order(v2, v1), ties.method='first')) 

# v1 v2 rank1 rank2 
# 1 2 1  1  2 
# 2 1 1  2  1 
# 3 1 3  4  4 
# 4 2 2  3  3 
+1

Zuerst wird 'ties.method' nicht benötigt,' order' hat keine Verbindungen. Zweitens versagt es mit diesen Daten: 'x <- data.frame (v1 = c (2,3,1,2,1), v2 = c (1,1,3,2,1))', so ist es einfach falsch. – user

2

order funktioniert, aber Datenrahmen für die Manipulation, prüfen Sie auch die plyr und dplyr Pakete.

> arranged_x <- arrange(x, v2, v1) 
0

Hier schaffen wir eine Folge von Zahlen und es dann neu ordnen, als ob es in der Nähe der geordneten Daten erstellt wurde:

x$rank <- seq.int(nrow(x))[match(rownames(x),rownames(x[order(x$v2,x$v1),]))] 

Oder:

x$rank <- (1:nrow(x))[order(order(x$v2,x$v1))] 

Oder auch:

x$rank <- rank(order(order(x$v2,x$v1))) 
Verwandte Themen