R_Language 板


LINE

※ 引述《bedroom0204 (khkh)》之铭言: : : 程式谘询(我想用R 做某件事情,但是我不知道要怎麽用R 写出来) : : [软体熟悉度]: : 请把以下不需要的部份删除 : 新手(没写过程式,R 是我的第一次) : [问题叙述]: : 我希望可以将1~10人的数据合成呈现, : 每个人都会有sta, dur数据,再计算出r : 我本来是写死的,也就是: : r1=trunc(r*(dur01/org)+sta01) : r2=trunc(r*(dur02/org)+sta02) : r3=trunc(r*(dur03/org)+sta03) : 但如果我要将1~10人(subjects)作为一个变数, : 能否用for回圈产生这些句子呢?还是要用其他手法? : 也就是当subjects=1,r1=trunc(r*(dur01/org)+sta01) : subjects=5,r1=trunc(r*(dur01/org)+sta01) : r2=trunc(r*(dur02/org)+sta02) : r3=trunc(r*(dur03/org)+sta03) : r4=trunc(r*(dur04/org)+sta04) : r5=trunc(r*(dur05/org)+sta05) 练习写一下,很初阶的写法,不知道是不是你要的~ library(data.table) dt_r<-data.table(dur=1:10,sta=11:20) r<-1 org<-1 k<-0 rn<-data.table(subject=1:55,n=1:55,rn=1:55) for(i in 1:10){ for(j in 1:i){ k=k+1 rn$subject[k]=i rn$n[k]=j rn$rn[k]=with(dt_r,trunc(r*(dur[j]/org+sta[j]))) } } rn subject n rn 1: 1 1 12 2: 2 1 12 3: 2 2 14 4: 3 1 12 5: 3 2 14 6: 3 3 16 7: 4 1 12 8: 4 2 14 9: 4 3 16 10: 4 4 18 11: 5 1 12 12: 5 2 14 13: 5 3 16 14: 5 4 18 15: 5 5 20 16: 6 1 12 17: 6 2 14 18: 6 3 16 19: 6 4 18 20: 6 5 20 21: 6 6 22 22: 7 1 12 23: 7 2 14 24: 7 3 16 25: 7 4 18 26: 7 5 20 27: 7 6 22 28: 7 7 24 29: 8 1 12 30: 8 2 14 31: 8 3 16 32: 8 4 18 33: 8 5 20 34: 8 6 22 35: 8 7 24 36: 8 8 26 37: 9 1 12 38: 9 2 14 39: 9 3 16 40: 9 4 18 41: 9 5 20 42: 9 6 22 43: 9 7 24 44: 9 8 26 45: 9 9 28 46: 10 1 12 47: 10 2 14 48: 10 3 16 49: 10 4 18 50: 10 5 20 51: 10 6 22 52: 10 7 24 53: 10 8 26 54: 10 9 28 55: 10 10 30 subject n rn 改用matrix写 dt_r.m<-matrix(1:20,10,2) r<-1 org<-1 rn1<-rep(1:10,1:10) tmp = rle(rn1) rn2<-do.call(c, sapply(tmp$lengths, function(x) 1:x)) rn.m<-matrix(cbind(rn1,rn2),55,2) rn.m1<-cbind(rn.m,trunc(r*(dt_r.m[rn.m[,2],1]/org+dt_r.m[rn.m[,2],2]))) rn.m1 [,1] [,2] [,3] [1,] 1 1 12 [2,] 2 1 12 [3,] 2 2 14 [4,] 3 1 12 [5,] 3 2 14 [6,] 3 3 16 [7,] 4 1 12 [8,] 4 2 14 [9,] 4 3 16 [10,] 4 4 18 [11,] 5 1 12 [12,] 5 2 14 [13,] 5 3 16 [14,] 5 4 18 [15,] 5 5 20 [16,] 6 1 12 [17,] 6 2 14 [18,] 6 3 16 [19,] 6 4 18 [20,] 6 5 20 [21,] 6 6 22 [22,] 7 1 12 [23,] 7 2 14 [24,] 7 3 16 [25,] 7 4 18 [26,] 7 5 20 [27,] 7 6 22 [28,] 7 7 24 [29,] 8 1 12 [30,] 8 2 14 [31,] 8 3 16 [32,] 8 4 18 [33,] 8 5 20 [34,] 8 6 22 [35,] 8 7 24 [36,] 8 8 26 [37,] 9 1 12 [38,] 9 2 14 [39,] 9 3 16 [40,] 9 4 18 [41,] 9 5 20 [42,] 9 6 22 [43,] 9 7 24 [44,] 9 8 26 [45,] 9 9 28 [46,] 10 1 12 [47,] 10 2 14 [48,] 10 3 16 [49,] 10 4 18 [50,] 10 5 20 [51,] 10 6 22 [52,] 10 7 24 [53,] 10 8 26 [54,] 10 9 28 [55,] 10 10 30 data.table的set我还是不太会用 orz



※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 27.147.47.152
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/R_Language/M.1483356867.A.8B2.html ※ 编辑: criky (27.147.47.152), 01/02/2017 19:35:14
1F:→ celestialgod: data.table用for做assign会慢到靠北喔~~ 01/02 20:25
2F:→ celestialgod: data.table请用set 01/02 20:25
3F:→ criky: 意思是把 <- 改成 = 吗? 01/02 21:00
4F:→ celestialgod: ?data.table::set 01/02 21:02
5F:→ criky: 喔!我看到了,我改看看 01/02 21:08
※ 编辑: criky (27.147.47.152), 01/04/2017 22:15:12
6F:推 cywhale: for(j in colnames(dt)) set(dt,j=j,value=fun(dt[[j]])) 01/06 09:40
7F:→ cywhale: set语法大概都这样,套用你想用的function or运算式即可 01/06 09:41
8F:→ criky: 谢谢cy大~ 01/06 12:37
※ 编辑: criky (27.147.47.152), 01/17/2017 22:41:01







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灯, 水草

请输入看板名称,例如:BabyMother站内搜寻

TOP