R_Language 板


LINE

※ 引述《anakinyen (我在台北 天气晴)》之铭言: : 遇到一个可能是很新手的问题 : 跳出回圈指令跑完後 : + break : + } : Error in as.POSIXct.default(time1) : : do not know how to convert 'time1' to class “POSIXct” 这问题是你的time1不是时间格式,是character造成的 : > sambar[ , diffTime := NULL] : Warning message: : In `[.data.table`(sambar, , `:=`(diffTime, NULL)) : : Adding new column 'diffTime' then assigning NULL (deleting it). 这个也同理 : 我猜是因为difftime预设的处理资料格式是 hh:mm,没有把日期考虑进去 这个猜测不对,difftime吃的是POSIXct 或是 POSIXlt class的东西 你在用read.csv读入资料的时候,你那个时间格式不会被正确解读成那两个class 所以只会被当成字串处理,因此我下面给你一段程式去把你的时间格式转成POSIXct : 但我试了半天都没改成功 : 也不太确定我的资料档日期格式是否正确 : 目前格式长这样 2012/11/1 6:04,不知道1号是不是该改成01,6点该改成06 ? : 再麻烦大大们帮忙了,感谢 资料读入後,请用 library(data.table) sambar <- read.csv(...) setDT(sambar) sambar[ , time1 := as.POSIXct(time1, format = "%Y/%m/%d %H:%M")] # time1是你的时间变数 : ※ 引述《celestialgod (天)》之铭言: : : 我用while + data.table做,若用data.frame会复制很多次,效率会不彰 : : library(data.table) : : # 产生资料 : : numObs <- 50 : : numInd <- 5 : : DT <- data.table(ind = paste0("A", sample(numInd, numObs, TRUE)), : : time = strptime("2012/12/11", "%Y/%m/%d") + : : sample(86400, numObs, TRUE), : : obs = rnorm(numObs)) : : # 排序 : : setorder(DT, ind, time, obs) : : # 移除掉时间差小於六小时的 : : k <- 1 : : while ( TRUE ) { : : # 计算时间差,以小时表示 : : DT[ , diffTime := difftime(time, time[min(k, .N)], units="hours"), by = ind] : : # 留下自己那一组 : : set(DT, which(DT$diffTime == 0), which(names(DT) == "diffTime"), 1e6) : : # 留下时间差超过六小时的 : : DT <- DT[abs(diffTime) > 6, ] : : # 下一组 : : k <- k + 1 : : # 如果k大於某组的观测值数目就跳离回圈 : : if (k > max(DT[ , .(numObsGroup = .N), by = ind]$numObsGroup)) : : break : : } : : DT[ , diffTime := NULL] : : 五万笔观测值,一千个个体,耗时0.23秒 (平均一个个体50个观测值) : : 五十万笔观测值,一千个个体,耗时0.39秒 (平均一个个体500个观测值) : : 我觉得这个速度应该可以接受 : : 不过我的区间只有24小时,所以可能都很快就筛选完了 : : 有人可以试试看更长时间的表现 : : 有问题或任何人有更好解法,欢迎提供,感谢 : : Note: 间隔一百天,五十万笔观测值,一千个个体,耗时18.33秒 --



※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 111.246.24.51
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/R_Language/M.1486553955.A.05A.html
1F:推 anakinyen: 已加入新的这行指令,但最後还是出现相同的错误讯息@@ 02/08 23:13
str(sambar) 看一下结果是什麽
2F:推 anakinyen: $ Time: POSIXct, format: "2009-12-05 20:00:00" "20 02/08 23:28
一样的错误是这一个吗? Error in as.POSIXct.default(time1) 还是In `[.data.table`(sambar, , `:=`(diffTime, NULL)) : Adding new column 'diffTime' then assigning NULL (deleting it). 不管是哪个,记得要把下面这段改成你的时间变数名称 DT[ , diffTime := difftime(Time, Time[min(k, .N)], units="hours"), by = ind] 如果改过还是有问题,可能要把你资料给我看一下
3F:推 anakinyen: 两个错误都还是存在,不过把下面的时间变数修正後 02/08 23:43
4F:→ anakinyen: 两个错误都不见了。 02/08 23:45
5F:→ anakinyen: 原来就卡在两个t的大小写。以後得要好好跟R培养感情 02/08 23:46
6F:→ anakinyen: 非常感谢您的帮忙!!! 02/08 23:47
搞定就好 ※ 编辑: celestialgod (111.246.24.51), 02/09/2017 00:26:36







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

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

TOP