【发布时间】:2022-01-12 21:56:54
【问题描述】:
我有一个数据框,我想定义多个列,这些列具有在变量的原始版本(列)上操作的相同函数(ntile)。我不确定循环或其他东西是否会起作用,但下面的示例是一个玩具示例。我的实际数据框有超过 20 个变量需要处理。
基本上,我想为我的数据框中的每个数字变量创建一个名为“original_name”_bin 的变量。这些 _bin 变量只是在原始非 _bin 版本上操作的ntile 函数:
dat1 <- read.table(text = "x1 x2
10 20
20 30.5
30 40.5
40 20.12
50 25
70 86
80 75
90 45 ", header = TRUE)
num_names <- paste(colnames(dat1[sapply(dat1, is.numeric)]))
bin_names <- paste(colnames(dat1[sapply(dat1, is.numeric)]), "bin", sep = "_")
# Want to make columns in data frame where the var_bin is:
dat1$x1_bin <- ntile(dat1$x1, n = 10)
# loop
for (i in 1:length(bin_names)){
assign(paste0("dat1$", bin_names[i]), ntile(???, 10))
}
【问题讨论】: