{base}R Documentation

Coerce to a Data Frame


Functions to check if an object is a data frame, or coerce it if possible.

Usage, row.names = NULL, optional = FALSE, ...)
## S3 method for class 'character':, ...,
              stringsAsFactors = default.stringsAsFactors())
## S3 method for class 'matrix':, row.names = NULL, optional = FALSE, ..., 
              stringsAsFactors = default.stringsAsFactors())


x any R object.
row.names NULL or a character vector giving the row names for the data frame. Missing values are not allowed.
optional logical. If TRUE, setting row names and converting column names (to syntactic names) is optional.
... additional arguments to be passed to or from methods.
stringsAsFactors logical: should the character vector be converted to a factor?

Details is a generic function with many methods, and users and packages can supply further methods.

If a list is supplied, each element is converted to a column in the data frame. Similarly, each column of a matrix is converted separately. This can be overridden if the object has a class which has a method for two examples are matrices of class "model.matrix" (which are included as a single column) and list objects of class "POSIXlt" which are coerced to class "POSIXct".

Arrays can be converted to data frames. One-dimensional arrays are treated like vectors and two-dimensional arrays like matrices. Arrays with more than two dimensions are converted to matrices by ‘flattening’ all dimensions after the first and creating suitable column labels.

Character variables are converted to factor columns unless protected by I.

If a data frame is supplied, all classes preceding "data.frame" are stripped, and the row names are changed if that argument is supplied.

If row.names = NULL, row names are constructed from the names or dimnames of x, otherwise are the integer sequence starting at one. Few of the methods check for duplicated row names. Names are removed from vector columns unless I.

Value returns a data frame, normally with all row names "" if optional = TRUE. returns TRUE if its argument is a data frame (that is, has "data.frame" amongst its classes) and FALSE otherwise.


Chambers, J. M. (1992) Data for models. Chapter 3 of Statistical Models in S eds J. M. Chambers and T. J. Hastie, Wadsworth & Brooks/Cole.

See Also

data.frame, for the table method (which has additional arguments if called directly).

[Package base version 2.5.0 Index]