That works!! Very nice way to do it! Thank you, Henrique! Rama Ramakrishnan
On Thu, Jun 25, 2009 at 10:11 AM, Henrique Dallazuanna <www...@gmail.com>wrote: > Try this: > > y$values <- diag(x[y$ltrs, y$mnths]) > > On Thu, Jun 25, 2009 at 11:02 AM, Rama Ramakrishnan <r...@alum.mit.edu>wrote: > >> Dear R-Users, >> I need to lookup values from a 2-d table using the row names and column >> names as indices. I was wondering if there's a way to do this without an >> explicit loop. >> >> Example: >> #x is the 2-d table that holds the values >> >> x <- matrix(rnorm(26*12),nrow=26) >> >> rownames(x) <- letters >> >> colnames(x) <- month.name >> >> >> #y is a data frame that has the "keys" I want to use as indices into x >> >> y <- data.frame(ltrs=sample(letters,5),mnths=sample(month.name >> ,5),values=0) >> >> >> #I want to fill in the "values" column using the "ltrs" and "mnths" >> columns >> as keys to look up >> >> # the associated value from x >> >> #One way to do this is with a FOR loop >> >> for (i in 1:nrow(y)) {y$val[i] <- x[y$ltrs[i],y$mnths[i]]} >> >> >> My question: Is there a more efficient way (e.g., one without using an >> explicit loop) to do this? >> >> >> Thanks in advance! >> >> >> -Rama Ramakrishnan >> >> [[alternative HTML version deleted]] >> >> ______________________________________________ >> R-help@r-project.org mailing list >> https://stat.ethz.ch/mailman/listinfo/r-help >> PLEASE do read the posting guide >> http://www.R-project.org/posting-guide.html >> and provide commented, minimal, self-contained, reproducible code. >> > > > > -- > Henrique Dallazuanna > Curitiba-Paraná-Brasil > 25° 25' 40" S 49° 16' 22" O > [[alternative HTML version deleted]]
______________________________________________ R-help@r-project.org mailing list https://stat.ethz.ch/mailman/listinfo/r-help PLEASE do read the posting guide http://www.R-project.org/posting-guide.html and provide commented, minimal, self-contained, reproducible code.