GeoDjango 上的剥离 Z 维度(强制 2D 几何)
Strip Z dimension on GeoDjango (Force 2D geometry)
在我的项目中,我需要从 shapefiles 中导入一些几何图形。
其中一些是 MULTIPOLYGON Z
类型,但所有 Z 坐标都是 0 值。
当我尝试保存几何体时,出现错误:
"Geometry has Z dimension but column does not"
剥离 Z 维度的最佳方法是什么?
我的代码:
ds = DataSource(file_path, encoding='ISO-8859-1')
layers = ds[0]
#need something HERE to coerce geometry to 2D
obj=MyModel(geometry=GEOSGeometry(layers[0].geom.hex))
obj.save()
如果您有 SQL 访问权限,您可以通过 ST_Force2D
(or ST_Force_2D
for older versions) 获得此权限。
您也可以通过修改类型来更正来源table,例如:
ALTER TABLE my_table
ALTER COLUMN geom TYPE geometry(MultiPolygon,4326) USING ST_Force2D(geom);
感谢您的回复,Mike T。
问题是我需要使用 GeoDjango framework 来创建它,而不是直接访问 Postgis 数据库。
其实经过一番努力,我找到了解决办法。我需要使用 OGRGeometry
对象中的 .clone()
方法。现在,我可以更改 coord_dim
属性。如果我在原始对象中更改 coord_dim
,什么也不会发生。
这是我的代码:
ds = DataSource(file_path, encoding='ISO-8859-1')
layers = ds[0]
#HERE IS THE TRICK
new_layer = layers[0].geom.clone()
new_layer.coord_dim = 2
obj=MyModel(geometry=GEOSGeometry(layers[0].geom.hex))
obj.save()
在我的项目中,我需要从 shapefiles 中导入一些几何图形。
其中一些是 MULTIPOLYGON Z
类型,但所有 Z 坐标都是 0 值。
当我尝试保存几何体时,出现错误:
"Geometry has Z dimension but column does not"
剥离 Z 维度的最佳方法是什么?
我的代码:
ds = DataSource(file_path, encoding='ISO-8859-1')
layers = ds[0]
#need something HERE to coerce geometry to 2D
obj=MyModel(geometry=GEOSGeometry(layers[0].geom.hex))
obj.save()
如果您有 SQL 访问权限,您可以通过 ST_Force2D
(or ST_Force_2D
for older versions) 获得此权限。
您也可以通过修改类型来更正来源table,例如:
ALTER TABLE my_table
ALTER COLUMN geom TYPE geometry(MultiPolygon,4326) USING ST_Force2D(geom);
感谢您的回复,Mike T。
问题是我需要使用 GeoDjango framework 来创建它,而不是直接访问 Postgis 数据库。
其实经过一番努力,我找到了解决办法。我需要使用 OGRGeometry
对象中的 .clone()
方法。现在,我可以更改 coord_dim
属性。如果我在原始对象中更改 coord_dim
,什么也不会发生。
这是我的代码:
ds = DataSource(file_path, encoding='ISO-8859-1')
layers = ds[0]
#HERE IS THE TRICK
new_layer = layers[0].geom.clone()
new_layer.coord_dim = 2
obj=MyModel(geometry=GEOSGeometry(layers[0].geom.hex))
obj.save()