0

我想从空间中删除具有某些值的行,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”

bd 属性

类:空间线数据帧

特点: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),]改用

4

1 回答 1

0

在这一点上,我不再相信它bd是一个空间对象,或者这个:

bd@data[- grep("xcluded", bd@data$Notes),]

不是产生此错误的行:

Error: trying to get slot "data" from an object (class "data.frame") that is not an S4 object

该错误表示它正在尝试从数据帧中获取数据槽。它与子集无关grep

我可以复制该错误消息:

> d = data.frame(x=1:10)
> d@data
Error: trying to get slot "data" from an object (class "data.frame") that is not an S4 object 
> 

但我无法用空间 sp 类对象复制它:

> Sldf
class       : SpatialLinesDataFrame 
features    : 2 
extent      : 1, 3.05, 1, 3.05  (xmin, xmax, ymin, ymax)
crs         : NA 
variables   : 1
names       :  Z 
min values  : AA 
max values  : AB 
> Sldf@data
   Z
1 AA
2 AB
> Sldf@data[-grep("B",Sldf@data$Z),,drop=FALSE]
   Z
1 AA
于 2019-12-08T20:58:10.480 回答