创建一个形状文件

时间:2012-11-02 15:33:42

标签: python ogr

我想用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“

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

2 个答案:

答案 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。)