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
Другие вопросы по тегам