On Mar 14, 2011, at 2:52 PM, andrija djurovic wrote:
Hi R users,
I have following data frame
df<-data.frame(q1=c(0,0,33.33,"check"),q2=c(0,33.33,"check",9.156),
q3=c("check","check",25,100),q4=c(7.123,35,100,"check"))
and i would like to replace every element that is less then 10
with . (dot)
in order to obtain this:
q1 q2 q3 q4
1 . . check .
2 . 33.33 check 35
3 33.33 check 25 100
4 check . 100 check
I had a lot of difficulties because each variable is factor.
Right, so comparisons with "<" will throw an error. I would sidestep
the factor problem with stringsAsFactors=FALSE in the data.frame call.
You might want to reconsider the "." as a missing value. If you are
coming from a SAS background, you should try to get comfortable with
NA or NA_character as a value.
df<-data.frame(q1=c(0,0,33.33,"check"),q2=c(0,33.33,"check",9.156),
q3=c("check","check",25,100),q4=c(7.123,35,100,"check"),
stringsAsFactors=FALSE)
is.na(df) <- t(apply(df, 1, function(x) as.numeric(x) < 10))
Warning messages:
1: In FUN(newX[, i], ...) : NAs introduced by coercion
2: In FUN(newX[, i], ...) : NAs introduced by coercion
3: In FUN(newX[, i], ...) : NAs introduced by coercion
4: In FUN(newX[, i], ...) : NAs introduced by coercion
> df
q1 q2 q3 q4
1 <NA> <NA> check <NA>
2 <NA> 33.33 check 35
3 33.33 check 25 100
4 check <NA> 100 check
Could someone help me with this?
Thanks in advance for any help.
Andrija
[[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.
David Winsemius, MD
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.