繁体   English   中英

使用全局变量作为列名时使用 data.table 更新列

[英]Updating column using data.table when using global variable as column name

我正在尝试根据列中的值是否与外部变量匹配来更新 data.table 中的列。 我遇到的问题是在 data.table 语法中使用全局变量作为列名。

明确指定列名按预期工作并更新列。

dt[,`1:4880` := ifelse(`1:4880`==allele, 2, 1)]

但是,当通过变量引用该列时,我无法更新该列:

colname="1:4880"
dt[,..colname := ifelse(..colname==allele, 2, 1)]

output 不会更新由变量名称描述的列中的值,而是写入 df$..colname。 奇怪的是,output 是正确的,所以 ifelse function 正在按预期工作,它只是将 output 写入错误的列名。

有没有办法让:= 运算符识别指定为变量的列名?

lhs上,我们可以用()包装来评估值,然后使用get或在.SDcols中指定它

dt[, (colname) := ifelse(.SD[[1]] ==allele, 2, 1), .SDcols = colname]

目前尚不清楚allele是另一列还是具有某些价值的 object

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM