Tenho um vetor x, que gostaria de classificar com base na ordem dos valores no vetor y. Os dois vetores não têm o mesmo comprimento.
x <- c(2, 2, 3, 4, 1, 4, 4, 3, 3)
y <- c(4, 2, 1, 3)
O resultado esperado seria:
[1] 4 4 4 2 2 1 3 3 3
Aqui está um forro ...
y[sort(order(y)[x])]
[editar:] Isso se divide da seguinte forma:
order(y) #We want to sort by y, so order() gives us the sorting order
order(y)[x] #looks up the sorting order for each x
sort(order(y)[x]) #sorts by that order
y[sort(order(y)[x])] #converts orders back to numbers from orders
x
ey
.x <- c(1,4,2); y <- c(1,2,4)
por exemplo.que tal este
fonte
Você pode converter
x
em um fator ordenado:Obviamente, transformar seus números em fatores pode mudar radicalmente a forma como o código posterior reage
x
. Mas, como você não nos forneceu nenhum contexto sobre o que acontece a seguir, pensei em sugerir isso como uma opção.fonte
x
não no vetor de classificaçãoy
com ligeira alteração:x <- c(2, 2, 3, 4, 1, 4, 4, 3, 3, 6); y <- c(4, 2, 1, 3); as.numeric(as.character(sort(factor(x, unique(c(y, x))))))
E se?:
(O de Ian provavelmente ainda é melhor)
fonte
No caso de você precisar obter o pedido em "y", não importa se são números ou caracteres:
Por etapas:
fonte
[ Editar: claramente Ian tem a abordagem certa, mas vou deixar isso para a posteridade.]
Você pode fazer isso sem loops, indexando em seu vetor y. Adicione um valor numérico crescente a y e mescle-os:
fonte
O resultado em z: 4 4 4 2 2 1 3 3 3
As etapas importantes:
for (i in y) - Loops sobre os elementos de interesse.
z <- c (z, ...) - Concatena cada subexpressão por vez
rep (i, sum (x == i)) - Repete i (o elemento atual de interesse) sum (x == i) vezes (o número de vezes que encontramos i em x).
fonte
Além disso, você pode usar
sqldf
e fazer isso por umajoin
funçãosql
como a seguinte:fonte