我想在一列唯一字符串中创建一列(可能)非唯一字符串。
例如,考虑:
df <- data.frame(
'Initials' = c("AA","AB","AB")
, 'Data' = c(1,2,3)
)
df
Initials Data
1 AA 1
2 AB 2
3 AB 3
我想获得这个:
Initials Data
1 AA 1
2 AB (1) 2
3 AB (2) 3
谢谢!
注意:我知道我可以使用rownames来唯一标识该行,但我想保留存储在Initials列中的字符串,并附加一个数字。
答案 0 :(得分:4)
transform(df, Initials = ave(as.character(Initials), Initials,
FUN = function(x) if (length(x) > 1) paste0(x, " (", seq(x), ")") else x))
# Initials Data
# 1 AA 1
# 2 AB (1) 2
# 3 AB (2) 3
答案 1 :(得分:2)
w <- ave(df$Data, df$Initials, FUN = seq_along )
> df$Initials <- paste(df$Initials, "(", w, ")", sep = "")
# > df
# Initials Data
# 1 AA(1) 1
# 2 AB(1) 2
# 3 AB(2) 3