반응형
다른 벡터의 값을 기준으로 한 벡터를 정렬하려면 어떻게 해야 합니까?
저는 벡터 x를 가지고 있는데, 벡터 y의 값 순서에 따라 정렬하고 싶습니다.두 벡터의 길이가 같지 않습니다.
x <- c(2, 2, 3, 4, 1, 4, 4, 3, 3)
y <- c(4, 2, 1, 3)
예상 결과는 다음과 같습니다.
[1] 4 4 4 2 2 1 3 3 3
이것은 어떻습니까?
x[order(match(x,y))]
변환할 수 있습니다.x
순서 요인으로:
x.factor <- factor(x, levels = y, ordered=TRUE)
sort(x)
sort(x.factor)
분명히, 당신의 숫자를 요인으로 바꾸는 것은 다운스트림 코드가 반응하는 방식을 근본적으로 바꿀 수 있습니다.x
하지만 당신이 우리에게 다음에 무슨 일이 일어날지에 대한 어떠한 맥락도 제시하지 않았기 때문에, 저는 이것을 선택사항으로 제안할 것이라고 생각했습니다.
어때요?
rep(y,table(x)[as.character(y)])
(이안의 것이 아마도 여전히 더 나을 것입니다)
숫자든 문자든 "y"에 대한 주문이 필요한 경우:
x[order(ordered(x, levels = y))]
4 4 4 2 2 1 3 3 3
단계별:
a <- ordered(x, levels = y) # Create ordered factor from "x" upon order in "y".
[1] 2 2 3 4 1 4 4 3 3
Levels: 4 < 2 < 1 < 3
b <- order(a) # Define "x" order that match to order in "y".
[1] 4 6 7 1 2 5 3 8 9
x[b] # Reorder "x" according to order in "y".
[1] 4 4 4 2 2 1 3 3 3
[편집: 분명히 이안의 접근법이 옳지만, 나는 이것을 후세에 남길 것입니다.]
y 벡터에서 인덱싱하여 루프 없이 이 작업을 수행할 수 있습니다.증분 숫자 값을 y에 추가하고 병합합니다.
y <- data.frame(index=1:length(y), x=y)
x <- data.frame(x=x)
x <- merge(x,y)
x <- x[order(x$index),"x"]
x
[1] 4 4 4 2 2 1 3 3 3
x <- c(2, 2, 3, 4, 1, 4, 4, 3, 3)
y <- c(4, 2, 1, 3)
for(i in y) { z <- c(z, rep(i, sum(x==i))) }
결과는 z: 44 4 2 2 1 3 3
중요한 단계:
for(iin y) - 관심 요소를 루프합니다.
z <- c(z, ...) - 각 하위 표현식을 차례로 연결합니다.
rep(i, sum(x==i)) -- i(현재 관심 요소) sum(x==i)을 x에서 찾은 횟수만큼 반복합니다.
또한 사용할 수 있습니다.sqldf
그리고 a로 그것을 합니다.join
에서 기능하는.sql
다음을 좋아합니다.
library(sqldf)
x <- data.frame(x = c(2, 2, 3, 4, 1, 4, 4, 3, 3))
y <- data.frame(y = c(4, 2, 1, 3))
result <- sqldf("SELECT x.x FROM y JOIN x on y.y = x.x")
ordered_x <- result[[1]]
언급URL : https://stackoverflow.com/questions/1568511/how-do-i-sort-one-vector-based-on-values-of-another
반응형
'programing' 카테고리의 다른 글
이클립스용 JavaScript Editor 플러그인 (0) | 2023.07.06 |
---|---|
다른 테이블스페이스를 사용하여 쿼리에서 테이블 만들기(Oracle SQL) (0) | 2023.07.06 |
Spring Boot 2.0.0에서 인증 관리자를 자동으로 연결할 수 없습니다. (0) | 2023.07.01 |
원격 태그를 보는 방법? (0) | 2023.07.01 |
인터op dll이란 무엇입니까? (0) | 2023.07.01 |