私は1つの文字列(変数)を持つ複数の変数を持つデータフレームを持っており、an
変数の文字列がstring
に表示されるかどうかを調べようとしています。各an
変数には対応するcn
変数があります。たとえば、c1
にChecked
を含めるには、a1
の文字列がstring
に表示されるなどします。私はこのためのループソリューションを開発しましたが(この記事の最後にあるサンプルデータの一部)、これに適用されるファミリソリューションがあれば、それはより速く簡単にコーディングできますか?実際のデータには、100以上の変数があります。複数のforループにファミリソリューションを適用しますか?
#For loop solution
for (var in seq(2, 10, 2)){
for (i in 1:nrow(df)){
df[i, var]<-ifelse(grepl(df[i, var-1], df$string[i])=="TRUE", "Checked", "Unchecked")
}
}
#### Example data ####
a1<-c("zebra", "giraffe", "elephant")
a2<-c("hyena", "monkey", "antelope")
a3<-c("badger", "deer", "kangaroo")
a4<-c("tiger", "lion", "coyote")
a5<-c("penguin", "bear", "gorilla")
c1<-""
c2<-""
c3<-""
c4<-""
c5<-""
string<-c("elephant/bear/coyote/penguin/monkey",
"giraffe/antelope/monkey/gorilla/tiger",
"elephant/antelope/kangaroo/coyote/gorilla")
df<-cbind.data.frame(a1, c1, a2, c2, a3, c3, a4, c4, a5, c5, string,
stringsAsFactors=F)