gpt4 book ai didi

r - 如何根据R中不同列中行上方/下方行中的值创建列

转载 作者:行者123 更新时间:2023-12-04 09:40:19 25 4
gpt4 key购买 nike

我一直在想这个问题,想不出解决办法。我在 X 列中有数据,我想用它来创建 Z 列中的数据。我希望 Z 全部为 1,直到 X 中的一行中有两个 0,然后全部为 0。另外,在 W 列中,当从下往上看 Y 时,我希望最后的元素为 1,Y 连续包含两个 0。希望这是有道理的。我已经在 Z 列和 W 列中输入了它们最终应该如何显示。我正在尝试使用索引,但我很难弄清楚如何引用 X 列中 Z 的值所在行之后的行(因为 Z 的第 1 行中的值基于值X 中的第 2 行和第 3 行)。这应该是两个独立的函数,一个看开头,一个看结尾。它们都将分别应用于每一行,因此 X 列将产生两列,Z 如下所示,以及另一列,在这种情况下将全为 0。感谢您的帮助!

****** 我将列名从A B C D 到 X Y Z W 以避免混淆。抱歉,我在输入时没有想到这一点!

********* * 我真的很希望能够在没有函数或循环的情况下做到这一点,只需要使用索引。我想我可以使用一个函数来计算它,但由于它是一个大数据集,我希望它尽可能快。

code    X   Y   Z   W
A 1 0 1 0
A 1 0 1 0
A 0 0 1 0
A 1 0 1 0
A 1 0 1 0
A 1 0 1 0
A 1 0 1 0
A 0 0 1 0
A 1 0 1 0
A 0 0 0 0
A 0 0 0 0
A 1 0 0 0
A 0 0 0 0
A 0 0 0 0
A 0 0 0 0
A 0 0 0 0
A 0 0 0 0
A 0 0 0 0
A 0 0 0 0
A 0 0 0 0
A 0 0 0 0
B 0 0 0 0
B 0 0 0 0
B 0 0 0 0
B 0 0 0 0
B 1 1 0 0
B 0 0 0 0
B 1 0 0 0
B 0 0 0 0
B 1 0 0 0
B 0 0 0 0
B 0 0 0 0
B 1 0 0 0
B 0 1 0 0
B 0 0 0 0
B 0 0 0 0
B 0 1 0 1
B 0 1 0 1
B 0 1 0 1
B 0 0 0 1
B 0 1 0 1
B 0 1 0 1

以下与聚合一起使用的函数应该会给出我正在寻找的结果。感谢 Tyler 开始这个功能。我仍然觉得应该有一个更简单的方法来做到这一点,但现在应该这样做。感谢大家的意见!

我想我已经弄明白了,基于 Tyler 的代码,只是做了一些改动。我将使用聚合来应用这个函数,它应该都能解决。感谢所有的输入!

pat.finder <- function(var, value=0, fill1=1, fill2=0, rev=FALSE, seq=2){

if(var[1]==0 & rev==FALSE){

j<- rep(0,length(var))} else if(var[length(var)]==0 & rev == TRUE){

j<- rep(0,length(var))} else{

x <- if(rev) rle(rev(var)) else rle(var)
n <- which(x[[1]]>(seq-1) & x[[2]]==value)[1]-1
i <- sum(x[[1]][1:n])
j <- if(rev){
rev(c(rep(fill1, i), rep(fill2, length(var)-i)))
} else {
c(rep(fill1, i), rep(fill2, length(var)-i))
}
}

return(j)
}

最佳答案

可能有更快的方法,但这是我想出的:

dat <- read.table(text="code    A   B   C   D #read in your data
A 1 0 1 0
A 1 0 1 0
A 0 0 1 0
A 1 0 1 0
A 1 0 1 0
A 1 0 1 0
A 1 0 1 0
A 0 0 1 0
A 1 0 1 0
A 0 0 0 0
A 0 0 0 0
A 1 0 0 0
A 0 0 0 0
A 0 0 0 0
A 0 0 0 0
A 0 0 0 0
A 0 0 0 0
A 0 0 0 0
A 0 0 0 0
A 0 0 0 0
A 0 0 0 0
B 0 0 0 0
B 0 0 0 0
B 0 0 0 0
B 0 0 0 0
B 1 1 0 0
B 0 0 0 0
B 1 0 0 0
B 0 0 0 0
B 1 0 0 0
B 0 0 0 0
B 0 0 0 0
B 1 0 0 0
B 0 1 0 0
B 0 0 0 0
B 0 0 0 0
B 0 1 0 1
B 0 1 0 1
B 0 1 0 1
B 0 0 0 1
B 0 1 0 1
B 0 1 0 1", header=T)

现在代码:

A.rle <- rle(dat$A)
n <- which(A.rle[[1]]>1 & A.rle[[2]]==0)[1]-1
i <- sum(A.rle[[1]][1:n])
dat$C <- c(rep(1, i), rep(0, nrow(dat)-i))

B.rle <- rle(rev(dat$B))
n2 <- which(B.rle[[1]]>1 & B.rle[[2]]==0)[1]-1
i2 <- sum(B.rle[[1]][1:n2])
dat$D <- rev(c(rep(1, i2), rep(0, nrow(dat)-i2)))

编辑:我不完全理解您的想法,所以我尝试创建一个多功能的功能来满足您的需求。使用rev=TRUE查看结尾:

pat.finder <- function(var, value=0, fill1=1, fill2=0, rev=FALSE, seq=2){
x <- if(rev) rle(rev(var)) else rle(var)
n <- which(x[[1]]>(seq-1) & x[[2]]==value)[1]-1
i <- sum(x[[1]][1:n])
j <- if(rev){
rev(c(rep(fill1, i), rep(fill2, length(var)-i)))
} else {
c(rep(fill1, i), rep(fill2, length(var)-i))
}
return(j)
}

#TRY IT OUT
pat.finder(dat$B, rev=TRUE)

transform(dat, C=pat.finder(A), D = pat.finder(B, rev=TRUE)) #what I think you want

transform(dat, C=pat.finder(A, fill1='foo', fill2='bar'),
D = pat.finder(A, rev=TRUE))

transform(dat, C=pat.finder(A, value=1), D = pat.finder(B, rev=TRUE))

关于r - 如何根据R中不同列中行上方/下方行中的值创建列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9419548/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com