我有数据如下:
userID <- c(1,1,1,2,2,2,3,3,3)
product <- c("a","a","a","b","b","c","a","b","c")
df <- data.frame(userID, product)
对于每个“userID”,我想创建一个二进制指示符变量,如果有多个唯一产品,则为 1;如果所有产品都相同,则为 0。
所以我的填充向量看起来像:
df$result <- c(0,0,0,1,1,1,1,1,1)
# userID product result
# 1 1 a 0
# 2 1 a 0
# 3 1 a 0
# 4 2 b 1
# 5 2 b 1
# 6 2 c 1
# 7 3 a 1
# 8 3 b 1
# 9 3 c 1
例如。用户 1 只有一种不同的产品 ('a') -> 结果 = 0。用户 2 有多个不同的产品 ('b' 和 'c') -> 结果 = 1。