Мой набор данных состоит из LineString
, и я хочу отфильтровать отдельные линейные сегменты этого LineString
. Точнее, каждый отдельный сегмент улицы.
До сих пор я извлекал отдельные точки из набора данных и сохранял их в отдельном списке. Кроме того, я хотел бы снова собрать эти точки и создать из них отдельные LineString, чтобы сохранить их в Geodataframe. Данные имеют следующую форму:
LINESTRING (3275.284016199762 340555.8579582386, 3241.504528076811 340504.1348617533, 3245.415803206172 340501.457084205, 3280.414559049542 340552.7138220053, 3285.19053022
Моя проблема в том, что мне пришлось бы создавать и явно сохранять отдельный LineString
для каждой итерации. Кто-нибудь может мне с этим помочь? Есть ли лучший способ для этого?
from shapely.geometry import Point, LineString
#Loop over LineString and gather Points
c=[]
for i in range(0,end):
c.append(Point(route1.coords[i]))
iterator=len(c)
max=len(c)-1
#Loop to store LineStrings - got stuck here
for i in np.arange(0,iterator):
if i<max:
LineString([c[i], c[i+1]]).wkt
else:
break;
Результат должен выглядеть так:
Linestring(Point A, Point B)
Linestring(Point B, Point C)
Linestring(Point C, Point D)
...
Linestring(Point Y, Point Z)