Я хочу экспортировать матрицу в R (и сохранить имена обеих строк и столбцов). Когда я использую write.table или write.csv, я получаю матрицу с новым столбцом. Как я могу использовать эту функцию.Экспорт матрицы в r
Благодарим за помощь.
Я хочу экспортировать матрицу в R (и сохранить имена обеих строк и столбцов). Когда я использую write.table или write.csv, я получаю матрицу с новым столбцом. Как я могу использовать эту функцию.Экспорт матрицы в r
Благодарим за помощь.
Я не вижу проблемы. Вы не получите новый столбец, имена строк сохраняются как первый столбец в текстовом файле. Поэтому либо укажите столбец, где имена строк указаны в read.table
, либо используйте опцию row.names=FALSE
в write.table
.
Демонстрация:
mat <- matrix(1:10,ncol=2)
rownames(mat) <- letters[1:5]
colnames(mat) <- LETTERS[1:2]
mat
write.table(mat,file="test.txt") # keeps the rownames
read.table("test.txt",header=TRUE,row.names=1) # says first column are rownames
unlink("test.txt")
write.table(mat,file="test2.txt",row.names=FALSE) # drops the rownames
read.table("test.txt",header=TRUE)
unlink("test2.txt")
В любом случае, чтение файлов справки бы все это вам сказал.
Я предполагаю, что под «новым столбцом» вы подразумеваете имена строк, которые выписываются по умолчанию. Чтобы подавить их, установите row.names = FALSE
при вызове write.table
или write.csv
.
write.table package:utils R Documentation
Data Output
Description:
‘write.table’ prints its required argument ‘x’ (after converting
it to a data frame if it is not one nor a matrix) to a file or
connection.
Usage:
write.table(x, file = "", append = FALSE, quote = TRUE, sep = " ",
eol = "\n", na = "NA", dec = ".", row.names = TRUE,
col.names = TRUE, qmethod = c("escape", "double"))
write.csv(...)
write.csv2(...)
...
row.names: either a logical value indicating whether the row names of
‘x’ are to be written along with ‘x’, or a character vector
of row names to be written.
col.names: either a logical value indicating whether the column names
of ‘x’ are to be written along with ‘x’, or a character
vector of column names to be written. See the section on
‘CSV files’ for the meaning of ‘col.names = NA’.
hehe, +1 для фактического копирования файлов справки. Но '? Write.table' хватило бы ... –
+1 для копирования файлов справки –
Не нужно грубить об этом - например. Я проверял документы, но для write.matrix, и у него нет такой опции –