- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我目前正在尝试合并来自两个 df 眼动追踪数据的信息。在一个 df(行为)中,有与实验中每个试验相关联的开始和结束时间。在另一个 df(gaze) 中,记录了凝视的时间戳。我想通过每个凝视时间戳并评估它是否在试验的开始和结束时间内(从行为 df 中提取的信息),如果是,则将行为 df 中的试验信息添加到试验列中凝视 df.
dfs如下:
Behavioral df
StartTime EndTime Trial
1: 0 0.8 a
2: 1 1.8 b
3: 2 2.8 c
4: 3 3.8 d
Gaze df
Gaze x y Frame Trial
1: 0.00 100 200 126 NA
2: 0.20 101 201 126 NA
3: 0.40 102 202 127 NA
4: 0.80 103 203 127 NA
5: 0.60 104 204 127 NA
6: 0.90 105 205 127 NA
7: 1.20 106 206 128 NA
8: 1.40 107 207 128 NA
9: 1.60 108 208 128 NA
10: 2.02 109 209 129 NA
11: 2.50 110 210 129 NA
12: 2.90 111 211 129 NA
13: 3.10 112 212 130 NA
14: 3.79 113 213 130 NA
我想浏览一下凝视时间戳。即,对于 Gaze$Gaze[1]
,它是在 0 到 0.8 之间吗?是 >>> Gaze$Trial[1]=a
我试过了
for(i in Gaze$Gaze){
if(as.numeric(Gaze$Gaze[i]) >= as.numeric(Behavior$StartTime[i])){
if(as.numeric(Gaze$Gaze[i]) <= as.numeric(Behavior$EndTime[i])){
Gaze$Trial[i]<-Behavior$Trial[i]
}
}
else Gaze$Trial[i]<-NA
}
我得到错误:
Error in if (as.numeric(fakegaze$Gaze[i]) >= as.numeric(fakebehavior$StartTime[i])) { : argument is of length zero
我相信在合并信息之前我可能需要使用另一个 for 循环来分别遍历两个 df,但我不确定从哪里开始。谢谢!
数据:
library(data.table)
beh = setDT(structure(list(StartTime = c(0, 1, 2, 3), EndTime = c(0.8, 1.8, 2.8, 3.8
), Trial = c("a", "b", "c", "d")), row.names = c(NA, -4L), class = "data.frame"))
gaze = setDT(structure(list(Gaze = c(0, 0.2, 0.4, 0.8, 0.6, 0.9, 1.2, 1.4,
1.6, 2.02, 2.5, 2.9, 3.1, 3.79), x = 100:113, y = 200:213, Frame = c(126L,
126L, 127L, 127L, 127L, 127L, 128L, 128L, 128L, 129L, 129L, 129L,
130L, 130L), Trial = c(NA, NA, NA, NA, NA, NA, NA, NA, NA, NA,
NA, NA, NA, NA)), row.names = c(NA, -14L), class = "data.frame"))
最佳答案
您可以使用非等连接来更新凝视表中的 Trial:
gaze[, Trial := beh[.SD, on=.(StartTime <= Gaze, EndTime >= Gaze), x.Trial]]
Gaze x y Frame Trial
1: 0.00 100 200 126 a
2: 0.20 101 201 126 a
3: 0.40 102 202 127 a
4: 0.80 103 203 127 a
5: 0.60 104 204 127 a
6: 0.90 105 205 127 <NA>
7: 1.20 106 206 128 b
8: 1.40 107 207 128 b
9: 1.60 108 208 128 b
10: 2.02 109 209 129 c
11: 2.50 110 210 129 c
12: 2.90 111 211 129 <NA>
13: 3.10 112 212 130 d
14: 3.79 113 213 130 d
此方法假定 beh
中没有重叠区间(在这种情况下,正确的 Trial 可能不明确)。
(OP 没有用 data.table 标记问题或包含 library(data.table)
调用,但我假设他们根据表格的打印方式使用它.)
作为 .SD is locked
error bug 的解决方法, 我通常按照错误消息中的建议使用 copy(.SD)
。但是,正如 OP 在评论中指出的那样,这对于大数据来说可能很昂贵。通常等效的替代方法是翻转连接:
# convert to correct NA type
gaze[, Trial := rep(beh$Trial[NA_integer_], .N)]
# reversed update join
gaze[beh, on=.(Gaze >= StartTime, Gaze <= EndTime), Trial := i.Trial]
对于 OP 的情况,它似乎仍然产生了正确的结果。我通常avoid this kind of join因为我发现它更难阅读,而且它会产生奇怪的副作用。特别是,在 x[i, on=, v := i.v]
中,如果 i
的多行映射到 x
的同一行,只会使用最后匹配的行(没有警告或错误)。
关于r - 有条件地合并来自两个数据框的数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57167921/
如何在 2014-10-04 - 2014-10-30 仅工作日和 08.00 - 20.00 之间随机更新日期列? 2014-10-04 - 2014-10-30 random working-da
我有一个二维 (3x7) 数组,我想转换为一维数组,以便我提供的行位于中心。行值可能沿途变化,但必须位于中心。 #define numRows 3 #define numCols 7 #define
我有2张 table : 第一个是“人”: person_id, 人名 第二个是“PersonsGraphs”: person_id1, person_id2, 关系类型 我正在寻找一种建立“家谱”的
是否可以在序列化 JSON 响应的同时根据 If 条件排除某些元素? if(a == 1) { //show element } else { //don't show element }
是否可以在序列化 JSON 响应的同时根据 If 条件排除某些元素? if(a == 1) { //show element } else { //don't show element }
尝试使用 jQuery 编写一个条件,该条件基本上说明,如果 div.gathering 不包含 a.cat-link,则执行以下操作。我已经尝试过以下方法,但似乎不起作用。有人能解释一下吗? if(
该练习要求插入值 x 的副本(这也是要在列表中搜索的值),但前提是该位置是另一个值 n 的倍数。未指定副本应插入到 x 值之前还是之后。 我的问题是并非在所有情况下都插入副本。我认为问题在于,当我插入
我遇到了这个[问题]:How can I store values into a multi-parameter struct and pass typedef struct to a functio
出于某种原因,当我编写 getWinner() 时,它仅适用于 2 种情况(最后一行)。就对角线和列而言,我拥有其他一切,但第 2 行(嗯,三,但数组,所以 2)基本上只适用于 o。只有当 o 位于
我有一个问题。 我想将“guid”列中的值复制到“帖子内容” 所有行都在一个表“wp-posts”中 “postparent”列中的一行有一个值,而“ID”列中的另一项也有相同的值 我必须做的事情是
我想将两个像这样的表合并到一个表中,并为重复的键行添加合并表中最旧的 DateAdded 值。 (Key1,Key2) 是主键。 +-----------+-----------+------+---
通过下面的表格和数据,我试图获得最高的 effective_from每个唯一 brand 小于当前时间戳的值/model组合 - 实际上是每件商品的当前价格。 CREATE TABLE things
您能告诉我如何删除未知号码的最后一条记录(有条件)吗? 例如,在这种情况下我想删除id为6到10的记录。 注意:该表和记录不是恒定的。 +----+-----+---------+ | id | ur
这个问题不太可能对任何 future 的访客有帮助;它只与一个较小的地理区域、一个特定的时间点或一个非常狭窄的情况相关,通常不适用于全世界的互联网受众。如需帮助使此问题更广泛适用,visit the
我有两个表, 标签 -> id,name,description,user,status 标签_连接。 -> id, Label_id, 类别 所以有多个类别,假设 1 => 新的,2 => 旧的。
好的,我会长话短说。 这是我的代码 String s = edittextkata.getText().toString(); String[] vowels = {"a","
我有一个非常具体的要求,我发现很难做到,我需要查找并替换文件中的某些行,但问题是文本不同,唯一的好处是它们都有一个 .[扩展名] 例如: 30/07/2012 14:46 17
我有一个大型数据库,其中存在各种不一致之处。我想澄清的项目之一是根据人口更改国家/地区状态。 数据样本是: { "_id" : "D", "name" : "Deutschland", "pop" :
我需要将范围(有条件)中的唯一值组合到同一行的另一个范围中。 其实我前两天发过类似的问题Link所提供的答案在我提出上述问题时有效。 但后来,我遇到了一个新问题,我宁愿问一个新的问题,让它更清楚: (
我刚开始使用 VBA,并且正在努力处理需要清理的工作表。 我有一列包含混合邮政编码和城市名称的字符串。我想从 A 列中提取邮政编码并放在 B 列中,并在 C 列中提取带有下划线的城市名称。 我的(示例
我是一名优秀的程序员,十分优秀!