我对R比较新,很抱歉,如果这是基础知识。我有这个循环,里面有一个条件比较2个列表并返回一个TRUE / FALSE值的向量。我真正需要检查的是这个向量是否只包含TRUE值(意思是2个列表是相同的)
for ( i in 1:(length(sessions_items_list)-1)){
if (sessions_items_list[[i]]==sessions_items_list[[i+1]]){
identical_sessions_df [i,1] <- names(sessions_items_list[i])
identical_sessions_df [i,2] <- names(sessions_items_list[i+1])
#identical_sessions_df [i,3] <- sessions_items_list[[i]]
#identical_sessions_df [i,4] <- sessions_items_list[[i+1]]
}
}
以下是一些数据:
> sessions_items_list[[2]]
[1] "111502665618" "111505397996" "121238758674" "121480200508" "131159477858" "161469302097" "161474935929" "171526802604" "231197187139" "231381216285" "251502101205" "261650031415"
[13] "261652085962" "261652452940" "271538491767" "281398254987" "291227243345" "311065441334" "321561638226" "321566237993" "331042848072" "331251405185" "331366646532" "361096154736"
[25] "381043841996"
> sessions_items_list[[3]]
[1] "111502665618" "111505397996" "121238758674" "131159477858" "161469302097" "161474935929" "171526802604" "231197187139" "231381216285" "251502101205" "261647474153" "261650031415"
[13] "261652085962" "261652452940" "271538491767" "281398254987" "291227243345" "311065441334" "321561638226" "321566237993" "331042848072" "331251405185" "331366646532" "361096154736"
[25] "381043841996"
以下是条件结果示例:
> sessions_items_list[[2]]==sessions_items_list[[3]]
[1] TRUE TRUE TRUE FALSE FALSE FALSE FALSE FALSE FALSE FALSE FALSE TRUE TRUE TRUE TRUE TRUE TRUE TRUE TRUE TRUE TRUE TRUE TRUE TRUE TRUE
是否有一个简单的函数来检查这个谓词列表的值为TRUE(所有值都为TRUE)?
答案 0 :(得分:4)
也许尝试all
功能:
> x <- c(rep(TRUE, 5), FALSE)
> y <- c(rep(TRUE, 6))
> all(x)
[1] FALSE
> all(y)
[1] TRUE
正如其名称所示,它会检查所有值是否为TRUE。
答案 1 :(得分:1)
也许不用说,但是我经常想检查正面情况,即向量是否仅包含FALSE值。在这种情况下,请检查any
的值是否为true,如果没有(则为FALSE),则将其取反:
> x <- c(FALSE, TRUE, FALSE)
> y <- c(TRUE, TRUE, TRUE)
> z <- c(FALSE, FALSE, FALSE)
> !any(x)
[1] FALSE
> !any(y)
[1] FALSE
> !any(z)
[1] TRUE