我正在尝试使用以下数据在 R 中构建项目频率矩阵。
H_USERID H_AUDIOID
1 TRAAAAW128F429D538.h5
2 TRAAABD128F429CF47.h5
2 TRAAADZ128F9348C2E.h5
3 TRAAAEF128F4273421.h5
3 TRAAAFD128F92F423A.h5
3 TRAAAMO128F1481E7F.h5
3 TRAAAMQ128F1460CD3.h5
3 TRAAAPK128E0786D96.h5
3 TRAAARJ128F9320760.h5
4 TRAAAVG12903CFA543.h5
4 TRAAAVO128F93133D4.h5
4 TRAABCL128F4286650.h5
4 TRAABDL12903CAABBA.h5
我想要的只是一个表,其中唯一用户作为行,audioID 作为列。我知道我需要使用 dcast 方法来执行此操作,但无法弄清楚该怎么做。我尝试了以下代码,但我知道它不是正确的解决方案。
user = read.csv("temp.csv")
step1 = melt(user)
output <- dcast(step1, user$H_AUDIOID~value, fun.aggregate = length)
output = t(output)
所需的输出是:
user$H_AUDIOID TRAAAAW128F429D538.h5 TRAAABD128F429CF47.h5 TRAAADZ128F9348C2E.h5 TRAAAEF128F4273421.h5 TRAAAFD128F92F423A.h5 TRAAAMO128F1481E7F.h5 TRAAAMQ128F1460CD3.h5 TRAAAPK128E0786D96.h5 TRAAARJ128F9320760.h5 TRAAAVG12903CFA543.h5 TRAAAVO128F93133D4.h5 TRAABCL128F4286650.h5 TRAABDL12903CAABBA.h5
1 1 0 0 0 0 0 0 0 0 0 0 0 0
2 0 1 1 0 0 0 0 0 0 0 0 0 0
3 0 0 0 1 1 1 1 1 1 0 0 0 0
4 0 0 0 0 0 0 0 0 0 1 1 1 1
任何帮助都会很有用。