R_Language 板


LINE

※ 引述《thea (里A)》之铭言: : [问题类型]: : 程式谘询(我想用R 做某件事情,但是我不知道要怎麽用R 写出来) : [软体熟悉度]: : 入门(写过其他程式,只是对语法不熟悉) : [问题叙述]: : 拿到一个资料,是逗号分隔的档案 : 资料类似如下 : id,20140101 : user,ABC001,1 : user,ADE002,2 : user,TEX001,3 : event,ABC001,T,C : event,ADE002,P,RUR : event,TEX001,pej,C : id,20140201 : user,ABC001,1 : user,ADE002,2 : user,TEX001,3 : event,ABC001,T,C : event,ADE002,P,RUR : event,TEX001,pej,C : . : . : . : 也就是说,资料是以id为单位做切割,所以我需要整理成以下格式 : (以event为资料角度,把id跟user资料加入event) : id,event1,event2,event3,user : 20140101,ABC001,T,C,1 : 20140101,ADE002,P,PUR,2 : 20140101,TEX001,pej,C,3 : 20140201,ABC001,T,C,1 : 20140201,ADE002,P,PUR,2 : 20140201,TEX001,pej,C,3 : [程式范例]: : 直觉上应该是要用回圈来处理? : 不过因为有一些对照(user跟event) : 之前处理的格式都是比较整齐的csv/excel : 第一次遇到这种资料格式 : 找了一些资料有点没头绪,所以上来请教T__T : 感谢!! src = 'id,20140101 user,ABC001,1 user,ADE002,2 user,TEX001,3 event,ABC001,T,C event,ADE002,P,RUR event,TEX001,pej,C id,20140201 user,ABC001,1 user,ADE002,2 user,TEX001,3 event,ABC001,T,C event,ADE002,P,RUR event,TEX001,pej,C id,20140301 user,ABC001,1 user,ADE002,2 user,TEX001,3 event,ABC001,T,C event,ADE002,P,RUR event,TEX001,pej,C' lines = readLines(textConnection(src)) # 这里可以直接用 readLines(filename) splitList = strsplit(lines, ",") len = sapply(splitList, length) loc = which(len == 2) loc = c(loc, length(len)+1) dat = do.call(rbind, lapply(1:(length(loc)-1), function(i){ len_sub = len[(loc[i]+1):(loc[i+1]-1)] id = splitList[[loc[i]]] user = do.call(rbind, splitList[loc[i]+which(len_sub==3)]) event = do.call(rbind, splitList[loc[i]+which(len_sub==4)]) cbind(id[2], event[,2:4], user[match(event[,2],user[,2]),3]) })) dat # [,1] [,2] [,3] [,4] [,5] # [1,] "20140101" "ABC001" "T" "C" "1" # [2,] "20140101" "ADE002" "P" "RUR" "2" # [3,] "20140101" "TEX001" "pej" "C" "3" # [4,] "20140201" "ABC001" "T" "C" "1" # [5,] "20140201" "ADE002" "P" "RUR" "2" # [6,] "20140201" "TEX001" "pej" "C" "3" # [7,] "20140301" "ABC001" "T" "C" "1" # [8,] "20140301" "ADE002" "P" "RUR" "2" # [9,] "20140301" "TEX001" "pej" "C" "3" --



※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 123.205.27.107
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/R_Language/M.1442371798.A.0C3.html
1F:推 thea: 啊~~非常感谢版主 QAQ+++ 可以耶~~ 太感恩了!!! 09/16 22:34
2F:推 thea: 请问版主,我跑自己的资料的时候会出现最後面cbind的错误 09/20 11:16
3F:→ thea: 讯息是: 下标超出边界 对过所有参数应该都正确 09/20 11:17
print match(user[,2],event[,2])这个出来看 有没有超过user的matrix大小
4F:→ thea: 找到问题点了!是我在最後一行 user[,2]跟event[,2]对调 09/24 01:01
5F:→ thea: 卡了三天。。。谢谢版主大大 QQ 09/24 01:01
我match写反了...~"~ 我修正 抱歉.... ※ 编辑: celestialgod (140.109.73.159), 09/24/2015 08:09:20
6F:推 thea: 没有啦,跑你的资料都可以跑出来!!真的太感谢了!! 09/24 23:58







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:Boy-Girl站内搜寻

TOP