我想从空间中删除具有某些值的行,data.frame
因为标准 R似乎没有通过类对象grep()
的所有槽传播。sp
bd@data[- grep("xcluded", bd@data$Notes),]
它给了我一个错误:
错误:试图从不是 S4 对象的对象(类“data.frame”)中获取插槽“数据”
我读到sp.na.omit
可以删除NA
但不知道如何删除具有特定值的行(例如,删除在 bd@data$Notes 中具有“排除”的行)。有什么建议么?
抱歉,我无法通过 R 创建 shapefile 示例,但我会尝试提供有关我的 sp 数据框的更多信息:
> class(bd)
1 “空间线数据帧”
attr(,"包")
1个“sp”
类:空间线数据帧
特点:8855
范围:172.6811、174.5966、-36.36374、-34.42634(xmin、xmax、ymin、ymax)
crs : +proj=longlat +datum=WGS84 +ellps=WGS84 +towgs84=0,0,0
变量:134
名称:OBJECTID_1, Name_in_us, Unique_ID, RAMM_Road_, iSequence, SH, OBJECTID, ROADID, RoadLength, RoadNameAn, Displaceme, road_id, AvgWidth, pave, CJNEX_urba, ...
最小值:1, 014-0000, 1188496, 0, 0, No, 0, 0, 0, 012-0132 (805), 0-1008m, 0, 0, 混凝土, 农村, ...
最大值:5299, ZEALANDIA ST, 2044000001, 2065, 480, Yes, 999, 1683, 45826.7818765, ZIDICH ROAD, 9925-9966m, 3520, 18.2, Unsealed, Urban, ...
df(bd@lines) 内的折线
$行[[1000]]
“线条”类的对象
插槽“线”:
[ 1 ]
“线”类的对象
插槽“坐标”:
[,1] [,2]
[1,] 174.3629 -35.77290
[2,] 174.3627 -35.77281
[3,] 174.3624 -35.77276
bd@data[1000,]
OBJECTID_1 Name_in_us Unique_ID RAMM_Road_ iSequence SH OBJECTID ROADID RoadLength RoadNameAn Displaceme road_id AvgWidth ...
1000 1000 域 RD 1.16e+08 116 2 否 89 116 94.75686 域 RD (116) 0-95m ...
解决方案:1.作为下面的答案/评论 2.bd[- grep("xcluded", bd$Notes),]
改用