ฉันมี 2 data.frames ต่อไปนี้:
a1 <- data.frame(a = 1:5, b=letters[1:5])
a2 <- data.frame(a = 1:3, b=letters[1:3])
ฉันต้องการค้นหาแถว a1 ที่ a2 ไม่ได้
มีฟังก์ชันในตัวสำหรับการทำงานประเภทนี้หรือไม่?
(ps: ฉันได้เขียนวิธีแก้ปัญหาสำหรับฉันฉันแค่อยากรู้ว่าใครบางคนทำรหัสที่สร้างขึ้นแล้ว)
นี่คือทางออกของฉัน:
a1 <- data.frame(a = 1:5, b=letters[1:5])
a2 <- data.frame(a = 1:3, b=letters[1:3])
rows.in.a1.that.are.not.in.a2 <- function(a1,a2)
{
a1.vec <- apply(a1, 1, paste, collapse = "")
a2.vec <- apply(a2, 1, paste, collapse = "")
a1.without.a2.rows <- a1[!a1.vec %in% a2.vec,]
return(a1.without.a2.rows)
}
rows.in.a1.that.are.not.in.a2(a1,a2)
a2 <- data.frame(a = c(1:3, 1), b = c(letters[1:3], "c"))
. ทิ้งa1
ไว้เหมือนเดิม ลองเปรียบเทียบดู ฉันยังไม่ชัดเจนแม้แต่ในการอ่านตัวเลือกว่าวิธีที่เหมาะสมคือการแสดงรายการองค์ประกอบทั่วไปเท่านั้น