On Dec 4, 2009, at 11:55 AM, Allen L wrote:


Dear R forum,
I want to replace all the elements in a data frame (dd) which match the
character "x" with "0".
What's the most elegant way of doing this (there must be an easy way which
I've missed)? I settled on the following loop:

for(i in 5:12){ # These are the column of dd I am interested
in
dd[which(dd[,i]=="x"),i]<-0
}

The problem with this is that the columns which used to contain "x" are
still considered factors and I am unable to coerce them into numeric:

Converting the labels of fac.obj (a factor object) to numeric values is a FAQ (I forget the number, 7.<something>)

as.numeric(as.character( fac.obj ))

Factors are internally sets of numbers, but those numbers are not generally what people assign meaning to, and certainly not in your case where you assigned the character "0" to those rows where the labels were previously "x".

mean.species.biomass<-colMeans(as.numeric(dd.p[,5:12]))
Error in inherits(x, "data.frame") :
 (list) object cannot be coerced to type 'double'

I'm tried unclassing & reclassing, other functions etc. but nothing seems to
work. What is wrong?
Thanks in advance,
Allen
--
--

David Winsemius, MD
Heritage Laboratories
West Hartford, CT

______________________________________________
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.

Reply via email to