pmatch возвращает неправильное совпадение символов
У меня есть матрица слов символов (3 на 3) и словарь (n на 1). Я хочу найти символы, совпадающие со словарем, будет заменен на положение символа, существующее в словаре, и будут удалены все несоответствующие слова (либо NA, либо NULL). Я пробовал просто pmatch
, Но это не работает. Я ищу такой результат,
1 5 2
1 4 NA
3 NA 2
но получить результат таким образом, [1] 1 NA 3 5 4 NA 2 NA NA
Я попробовал код ниже,
a <- matrix(c("456_rr", "432_uu", "522_kk", "456_rr", "432_tt", "522", "456_ss", "432", "522_kk"), nrow = 3, ncol = 3, byrow = TRUE) # WordTable
b <- matrix(c("456_rr","522_kk","456_ss", "432_tt", "432_uu"), nrow = 5, ncol = 1) # Dictionary
c <- pmatch(a, b)
print(c)
1 ответ
Решение
nrow
в "б" не правильно. Так должно быть 5
b <- matrix(c("456_rr","522_kk","456_ss", "432_tt",
"432_uu"), nrow = 5, ncol = 1)
v1 <- pmatch(a,b)
m1
#[1] 1 NA 3 5 4 NA 2 NA NA
dim(m1) <- dim(a)
m1
# [,1] [,2] [,3]
#[1,] 1 5 2
#[2,] NA 4 NA
#[3,] 3 NA NA
Если нам нужно получить индекс дубликатов, используйте duplicates.ok=TRUE
по умолчанию FALSE
`dim<-`(pmatch(a, b, duplicates.ok=TRUE), dim(a))
# [,1] [,2] [,3]
#[1,] 1 5 2
#[2,] 1 4 2
#[3,] 3 NA 2