我正在处理sf
对象,我有一个关于将用户定义的函数应用于数据框的问题。这是一个愚蠢的例子,但它类似于我试图解决一个更复杂的问题。我有一个名为的数据框names
,它有两列,每列都有一个县的名称。sf
我还阅读了包裹中包含的北卡罗来纳州数据。
require(sf)
name_1 <- c('Ashe','Alleghany','Surry')
name_2 <- c('Currituck','Northampton','Hertford')
names <- data.frame(cbind(name_1,name_2))
nc <- st_read(system.file("shape/nc.shp", package="sf"))
我要做的是创建一个函数,该函数沿着我的数据框的每一行,names
从 name_1 列中取出名称,从 name_2 列中取出名称,并查看它们是否使用中的几何数据相交nc
。我有:
check_intersection <- function(x){
return(st_intersects(nc[nc$NAME== x$name_1,],nc[nc$NAME==x$name_2,],sparse = FALSE))
}
apply(names,1,check_intersection)
但这会产生一个错误Error in x$name_1 : $ operator is invalid for atomic vectors
。对于 中的每一行,我如何告诉函数从适当的列中获取字符值names
?