63

Possible Duplicate:
Drop Columns R Data frame

Let's say I have a dataframe with column c1, c2, c3.

I want to list just c1 and c2. How do I do that?

I've tried:

head(data[column!="c3"])
head(data)[,2]
head(data[!"c3"])
Community
  • 1
  • 1
mythicalprogrammer
  • 4,167
  • 5
  • 30
  • 42

2 Answers2

130

In addition to tcash21's numeric indexing if OP may have been looking for negative indexing by name. Here's a few ways I know, some are risky than others to use:

mtcars[, -which(names(mtcars) == "carb")]  #only works on a single column
mtcars[, names(mtcars) != "carb"]          #only works on a single column
mtcars[, !names(mtcars) %in% c("carb", "mpg")] 
mtcars[, -match(c("carb", "mpg"), names(mtcars))] 
mtcars2 <- mtcars; mtcars2$hp <- NULL         #lost column (risky)


library(gdata) 
remove.vars(mtcars2, names=c("mpg", "carb"), info=TRUE) 

Generally I use:

mtcars[, !names(mtcars) %in% c("carb", "mpg")] 

because I feel it's safe and efficient.

Tyler Rinker
  • 99,090
  • 56
  • 292
  • 477
80

You can index and use a negative sign to drop the 3rd column:

data[,-3]

Or you can list only the first 2 columns:

data[,c("c1", "c2")]
data[,1:2]

Don't forget the comma and referencing data frames works like this: data[row,column]

tcash21
  • 4,455
  • 3
  • 29
  • 37