Каковы ограничения для классов столбцов в data.table?

StackOverflow https://stackoverflow.com/questions/7828428

  •  27-10-2019
  •  | 
  •  

Вопрос

ОБНОВИТЬ Эта проблема больше не актуальна для data.table Версии 1.8.0 и выше. Из файла новостей:

Столбцы символов теперь разрешены в ключах и предпочтительнее фактора. data.table () и setkey () больше не принуждают символ к фактору. Факторы все еще поддерживаются. Реализует FR#1493, FR#1224 и (частично) FR#951.

Оригинальный вопрос

Я стараюсь присоединиться к двум данным.tables. Тем не менее, успех соединения зависит от классов столбцов, которые я использую для сопоставления данных. Точнее, кажется, что столбцы не должны иметь класса «символ». Я не совсем понимаю причину, но я уверен, что упускаю что -то очевидное здесь. Так что помощь действительно ценится.

Вот пример:

#Objective: Select all rows from DT for which Region=="US", Year >= 5 & Year<=8, Cat="A"                 
library(data.table)
#Set-up data.table DT
DT <- data.table(Year=1:20, value=rnorm(20), Region=c(rep("US", 10), rep("EU", 10)),     Cat=c(rep("A", 7), rep("B", 7), rep("C", 6)))
setkey(DT, Region, Cat, Year)
#Set-up data.table int_DT to join with DT
years   <- 5:8
df      <- data.frame(Region=c("US", "EU"), Categ=c("A", "B"))
int_DT <- J(cbind(df[1, ], years))
#Join them: Works like a charm!
DT[int_DT]

#Let's assume that for any reason the columns in df are of class "character"
df$Region <- as.character(df$Region)
df$Categ  <- as.character(df$Categ)
#Rebuild int_DT
int_DT    <- J(cbind(df[1, ], years))
DT[int_DT]    
#Error in `[.data.table`(DT, int_DT) : 
#  unsorted column Region of i is not internally type integer.

#OK, maybe the problem is that the column classes in DT are factors, so change those:
DT[, Cat:=as.character(Cat)]
DT[, Region:=as.character(Region)]

DT[int_DT]
#Error in `[.data.table`(DT, int_DT) : 
#  When i is a data.table, x must be sorted to avoid a vector scan of x per row of i

Все еще не работает. Почему? Какое ограничение? Что мне скучать? Дополнительная информация: я использую Data.table 1.6.6 и R версии 2.13.2 (2011-09-30) на платформе: x86_64-PC-Linux-GNU (64-бит).

Это было полезно?

Решение

Вам не нужна операция объединения, чтобы получить желаемые результаты. Вы сказали:'Цель: выберите все строки из DT, для которого регион == "US", Год> = 5 и год <= 8, cat = "a"' '

DT[Region=="US" & Year>=5 & Year <= 8 & Categ=="A"]
     Year       value Region Categ
[1,]    5 -0.18631697     US     A
[2,]    6  1.40059083     US     A
[3,]    7  0.01848557     US     A

Но чтобы ответить на ваш вопрос о классах столбцов. Мне удалось заставить этот код работать, что по сути отражает ваш код выше:

> setkey(DT, Region, Categ, Year)
> df      <- data.frame(Region=c("US", "EU"), Categ=c("A", "B"))
> dt2 <- data.table(data.frame(df[1, ], Year=5:8))
Warning message:
In data.frame(df[1, ], Year = 5:8) :
  row names were found from a short variable and have been discarded
> dt1[dt2]
     Region Categ Year      value
[1,]     US     A    5 -0.5565422
[2,]     US     A    6 -0.1805841
[3,]     US     A    7  1.4474403
[4,]     US     A    8         NA

То же самое, с классами столбцов character:

df$Region <- as.character(df$Region)
df$Categ  <- as.character(df$Categ)
#Rebuild int_DT
dt2    <- J(cbind(df[1, ], Year=5:8))

Warning message:
In data.frame(..., check.names = FALSE) :
  row names were found from a short variable and have been discarded

setkey(dt2, Region)
dt1[dt2]
   Region Year       value Categ Categ.1 Year.1
       US    1  1.20152558     A       A      5
       US    2  1.89391079     A       A      5
       US    3 -1.76022634     A       A      5
       US    4  0.92454680     A       A      5
       US    5 -0.55654217     A       A      5
       ...
       snip 
       ...
       US    9  0.67936243     B       A      8
       US   10 -0.09355764     B       A      8
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top