I guess you are looking for get
which allows you to access the variable using a character :
for (v in c('mpg','cyl', 'disp', 'hp', 'drat')) {
dt[get(v) < mean(get(v)), c(v) := 0]
}
should work
mpg cyl disp hp drat wt qsec vs am gear carb
1: 21.0 0 0.0 0 3.90 2.620 16.46 0 1 4 4
2: 21.0 0 0.0 0 3.90 2.875 17.02 0 1 4 4
3: 22.8 0 0.0 0 3.85 2.320 18.61 1 1 4 1
4: 21.4 0 258.0 0 0.00 3.215 19.44 1 0 3 1
5: 0.0 8 360.0 175 0.00 3.440 17.02 0 0 3 2
6: 0.0 0 0.0 0 0.00 3.460 20.22 1 0 3 1
7: 0.0 8 360.0 245 0.00 3.570 15.84 0 0 3 4
8: 24.4 0 0.0 0 3.69 3.190 20.00 1 0 4 2
9: 22.8 0 0.0 0 3.92 3.150 22.90 1 0 4 2
10: 0.0 0 0.0 0 3.92 3.440 18.30 1 0 4 4
11: 0.0 0 0.0 0 3.92 3.440 18.90 1 0 4 4
12: 0.0 8 275.8 180 0.00 4.070 17.40 0 0 3 3
13: 0.0 8 275.8 180 0.00 3.730 17.60 0 0 3 3
14: 0.0 8 275.8 180 0.00 3.780 18.00 0 0 3 3
15: 0.0 8 472.0 205 0.00 5.250 17.98 0 0 3 4
16: 0.0 8 460.0 215 0.00 5.424 17.82 0 0 3 4
17: 0.0 8 440.0 230 0.00 5.345 17.42 0 0 3 4
18: 32.4 0 0.0 0 4.08 2.200 19.47 1 1 4 1
19: 30.4 0 0.0 0 4.93 1.615 18.52 1 1 4 2
20: 33.9 0 0.0 0 4.22 1.835 19.90 1 1 4 1
21: 21.5 0 0.0 0 3.70 2.465 20.01 1 0 3 1
22: 0.0 8 318.0 150 0.00 3.520 16.87 0 0 3 2
23: 0.0 8 304.0 150 0.00 3.435 17.30 0 0 3 2
24: 0.0 8 350.0 245 3.73 3.840 15.41 0 0 3 4
25: 0.0 8 400.0 175 0.00 3.845 17.05 0 0 3 2
26: 27.3 0 0.0 0 4.08 1.935 18.90 1 1 4 1
27: 26.0 0 0.0 0 4.43 2.140 16.70 0 1 5 2
28: 30.4 0 0.0 0 3.77 1.513 16.90 1 1 5 2
29: 0.0 8 351.0 264 4.22 3.170 14.50 0 1 5 4
30: 0.0 0 0.0 175 3.62 2.770 15.50 0 1 5 6
31: 0.0 8 301.0 335 0.00 3.570 14.60 0 1 5 8
32: 21.4 0 0.0 0 4.11 2.780 18.60 1 1 4 2
mpg cyl disp hp drat wt qsec vs am gear carb
You will see that it behave differently than with = F
:
dt[,"mpg"] # get a data.table of one column, idem dt[,.(mpg)]
dt[,mpg] # get a vector
var <- "mpg"
dt[,var] #error
dt[,get(var)] # same as dt[,mpg]
dt[,var,with = F] # same as dt[,"mpg"]