R data.table заменяет индекс значений из другого data.table

Привет все еще пытаюсь выяснить data.table. Если у меня есть data.table значений, таких как приведенные ниже, каков наиболее эффективный способ заменить значения из другого data.table?

set.seed(123456)

a=data.table(
  date_id = rep(seq(as.Date('2013-01-01'),as.Date('2013-04-10'),'days'),5),
  px =rnorm(500,mean=50,sd=5),
  vol=rnorm(500,mean=500000,sd=150000),
  id=rep(letters[1:5],each=100)
  )

b=data.table(
  date_id=rep(seq(as.Date('2013-01-01'),length.out=600,by='days'),5),
  id=rep(letters[1:5],each=600),
  px=NA_real_,
  vol=NA_real_
  )

setkeyv(a,c('date_id','id'))
setkeyv(b,c('date_id','id'))

То, что я пытаюсь сделать, это заменить px и vol в b с теми, гдеdate_id а такжеid match Я немного сбит с толку этим - я полагаю, что что-то вроде этого может быть способом, но я не думаю, что это сработает на практике.

b[which(b$date_id %in% a$date_id & b$id %in% a$id),list(px:=a$px,vol:=a$vol)]

РЕДАКТИРОВАТЬ

Я попробовал следующее

t = a[b,roll=T]
t[!is.na(px),list(px.1:=px,vol.1=vol),by=list(date_id,id)]

и получил сообщение об ошибке

Error in `:=`(px.1, px) : 
  := is defined for use in j only, and (currently) only once; i.e., DT[i,col:=1L] and DT[,newcol:=sum(colB),by=colA] are ok, but not DT[i,col]:=1L, not DT[i]$col:=1L and not DT[,{newcol1:=1L;newcol2:=2L}]. Please see help(":="). Check is.data.table(DT) is TRUE.

Ответы на вопрос(2)

Ваш ответ на вопрос