Мне трудно переключаться между фреймами данных и объектами зоопарка, особенно с сохранением значимых имен столбцов и несогласованностью между одномерными и многомерными случаями:
library(zoo)
#sample data, two species counts over time
t = as.Date(c("2012-01-01", "2012-01-02", "2012-01-03", "2012-01-04"))
n1 = c(4, 5, 9, 7) #counts of Lepisma saccharina
n2 = c(2, 6, 0, 11) #counts of Thermobia domestica
df = data.frame(t, n1, n2)
colnames(df) <- c("Date", "Lepisma saccharina", "Thermobia domestica")
#converting to zoo loses column names in univariate case...
> z1 <- read.zoo(df[,1:2]) #time series for L. saccharina
> colnames(z1)
NULL
> colnames(z1) <- c("Lepisma saccharina") #can't even set column name manually
Error in `colnames<-`(`*tmp*`, value = "Lepisma saccharina") :
attempt to set colnames on object with less than two dimensions
#... but not in multivariate case
> z2 <- read.zoo(df) #time series for both species
> colnames(z2)
[1] "Lepisma saccharina" "Thermobia domestica"
Чтобы вернуться от объекта зоопарка к фрейму данных в исходном формате, недостаточно использовать as.data.frame
, поскольку он не будет включать столбец «Дата» (даты попадают в названия строк): требуется дополнительная работа.
zooToDf <- function(z) {
df <- as.data.frame(z)
df$Date <- time(z) #create a Date column
rownames(df) <- NULL #so row names not filled with dates
df <- df[,c(ncol(df), 1:(ncol(df)-1))] #reorder columns so Date first
return(df)
}
Это отлично работает в многомерном случае, но явно не может восстановить значимое имя столбца в одномерном случае:
> df2b <- zooToDf(z2)
> df2b
Date Lepisma saccharina Thermobia domestica
1 2012-01-01 4 2
2 2012-01-02 5 6
3 2012-01-03 9 0
4 2012-01-04 7 11
> df1b <- zooToDf(z1)
> df1b
Date z
1 2012-01-01 4
2 2012-01-02 5
3 2012-01-03 9
4 2012-01-04 7
Есть ли простой способ справиться с обоими одномерными и многомерными случаями? Кажется, z1
нужно как-то запомнить имя столбца.
data.table
datatable.r-forge.r-project.org /datatable-faq.pdf, где разработчики отмечают. В[.data.frame
мы очень часто устанавливаемdrop=FALSE
. Когда мы забываем, ошибки могут возникнуть в крайних случаях, когда выбираются отдельные столбцы, и внезапно возвращается вектор, а не отдельный столбец data.frame. В[.data.table
мы воспользовались возможностью, чтобы сделать его последовательным и упасть. - person Silverfish   schedule 01.11.2013