3

我想使用 2 个点创建一个 shapefile(一条线)。

我有以下脚本:

import ogr, sys, os

line=ogr.Geometry(ogr.wkbLineString)
line.AddPoint(10,10)
line.AddPoint(20,20)

driver=ogr.GetDriverByName('ESRI Shapefile')
ds=driver.CreateDataSource('C:\test.shp')
layer=ds.CreateLayer('test', geom_type=ogr.wkbLineString)
fieldDefn=ogr.FieldDefn('id', ogr.OFTInteger)
layer.CreateField(fildDefn)
featureDefn=layer.GetLayerDefn()
feature=ogr.Feature(featureDefn)
feature.SetGeometry(line)
feature.SetField('id',1)
layer.CreateFeature(feature)

我有两个错误..

“错误 1:无法创建文件。shp 文件。错误 4:无法打开 Shapefile”

任何人都知道问题是什么?谁能帮我?非常感谢

4

2 回答 2

2

你忘了通知大地测量系统。下面的这种方式有效。

import ogr, sys, os
import osgeo.osr as osr

line=ogr.Geometry(ogr.wkbLineString)
line.AddPoint(10,10)
line.AddPoint(20,20)

driver=ogr.GetDriverByName('ESRI Shapefile')
ds=driver.CreateDataSource('test.shp')

srs = osr.SpatialReference()
srs.ImportFromEPSG(4326)

layer=ds.CreateLayer('test', srs, ogr.wkbLineString)
fieldDefn_=ogr.FieldDefn('id', ogr.OFTInteger)
layer.CreateField(fieldDefn_)
featureDefn=layer.GetLayerDefn()
feature=ogr.Feature(featureDefn)
feature.SetGeometry(line)
feature.SetField('id',1)
layer.CreateFeature(feature)
于 2016-06-27T18:46:43.180 回答
1

您需要替换\t字符;它们表示 python 字符串文字中的制表符。要么加倍斜线,要么使用原始 python 字符串:

ds=driver.CreateDataSource('C:\\test.shp')

或者

ds=driver.CreateDataSource(r'C:\test.shp')

(注意r字符串开头的 )。

于 2012-11-02T15:42:45.473 回答