Verilerimin bir veri tabanına ve takılı katsayılardan oluşan bir veri tabanına sahibim. Her satır için takılan değeri hesaplamak istiyorum. dt her a=="x"
satır içinR data.table eşleşen ürün sütun isimleriyle birlikte (her grup için)
dt = data.table(a = rep(c("x","y"), each = 5), b = rnorm(10), c = rnorm(10), d = rnorm(10))
coefs = data.table(a = c("x","y"), b = c(0, 1), d = c(2,3))
dt
# a b c d
# 1: x -0.25174915 -0.2130797 -0.67909764
# 2: x -0.35569766 0.6014930 0.35201386
# 3: x -0.31600957 0.4398968 -1.15475814
# 4: x -0.54113762 -2.3497952 0.64503654
# 5: x 0.11227873 0.0233775 -0.96891456
# 6: y 1.24077566 -1.2843439 1.98883516
# 7: y -0.23819626 0.9950835 -0.17279980
# 8: y 1.49353589 0.3067897 -0.02592004
# 9: y 0.01033722 -0.5967766 -0.28536224
#10: y 0.69882444 0.8702424 1.24131062
coefs # NB no "c" column
# a b d
#1: x 0 2
#2: y 1 3
, ben 0*b+2*d
istiyorum; ve her bir a=="y"
satırında dt için 1*b+3*d
istiyorum.
Sütun adı sabit kod olmadan bunu yapmak için bir veri yolu var mı? Sütun adlarını cols = colnames(coefs)[-1]
değişkenine koymaktan mutluluk duyuyorum.
Gruplar ve rbind
arasında geçiş yapmak çok kolaydır, bu nedenle gruplamada sorun çıkıyorsa, lütfen bu bölümü göz ardı edin.
Benzer sorum: http://stackoverflow.com/q/19279075/ Değeri için, birinin dinamik olarak isimleri eşleştirmekle ilgili kaygılanmasının doğal olduğunu düşünüyorum ve bu da bu soruyu "hareketli bir hedef haline getirmiyor" "hiç. – Frank