[R] Why copying columns of a data.frame becomes numeric?
Sarah Goslee
sarah.goslee at gmail.com
Fri Apr 12 21:42:52 CEST 2013
It's another reason not to use $ for extraction.
By default, R reduces dimensionality when subsetting, so mtcars$mpg
actually returns a numeric vector. With $, there's no way to override
the default behavior.
> data(mtcars)
> a <- mtcars$mpg
> class(a)
[1] "numeric"
> dim(a)
NULL
>
> a <- mtcars[, "mpg", drop=FALSE]
> class(a)
[1] "data.frame"
> dim(a)
[1] 32 1
Sarah
On Fri, Apr 12, 2013 at 3:32 PM, C W <tmrsg11 at gmail.com> wrote:
> Dear list,
>
> I want the 1st, 2nd, 5th, and 6th columns of mtcars. After copying them,
> the columns become numeric class rather than data frame.
>
> But, when I copy rows, they data frame retains its class. Why is this? I
> don't see why copying rows vs columns is so different.
>
>> class(mtcars)
> [1] "data.frame"
>> head(mtcars)
> mpg cyl disp hp drat wt qsec vs am gear carb
> Mazda RX4 21.0 6 160 110 3.90 2.620 16.46 0 1 4 4
> Mazda RX4 Wag 21.0 6 160 110 3.90 2.875 17.02 0 1 4 4
> Datsun 710 22.8 4 108 93 3.85 2.320 18.61 1 1 4 1
> Hornet 4 Drive 21.4 6 258 110 3.08 3.215 19.44 1 0 3 1
> Hornet Sportabout 18.7 8 360 175 3.15 3.440 17.02 0 0 3 2
> Valiant 18.1 6 225 105 2.76 3.460 20.22 1 0 3 1
>> a <- mtcars$mpg
>> class(a)
> [1] "numeric"
>> b <- mtcars[1:5, ]
>> class(b)
> [1] "data.frame"
>
>
> Thanks a lot,
> Mike
>
--
Sarah Goslee
http://www.functionaldiversity.org
More information about the R-help
mailing list