[英]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.