我想用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“
任何人都知道问题是什么? 谁能帮我? 非常感谢
答案 0 :(得分: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)
答案 1 :(得分:1)
您需要替换\t
个字符;它们表示python字符串文字中的制表符。要么斜杠加倍,要么改为使用原始python字符串:
ds=driver.CreateDataSource('C:\\test.shp')
或
ds=driver.CreateDataSource(r'C:\test.shp')
(注意字符串开头的r
。)