中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何創建Shapefile文件并寫入數據

發布時間:2021-06-07 14:11:30 來源:億速云 閱讀:520 作者:小新 欄目:開發技術

這篇文章將為大家詳細講解有關如何創建Shapefile文件并寫入數據,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

基本思路

使用GDAL創建Shapefile數據的基本步驟如下:

使用osgeo.ogr.Driver的CreateDataSource()方法創建osgeo.ogr.DataSource矢量數據集

使用osgeo.ogr.DataSource的CreateLayer()方法創建一個圖層

使用osgeo.ogr.FieldDefn()定義Shapefile文件的屬性字段

創建osgeo.ogr.Feature對象,設置每個屬性字段的值,使用Feature對象的SetGeometry()定義幾何屬性

創建Feature對象以后,使用osgeo.ogr.Layer的CreateFeature()添加Feature對象到當前圖層

重復步驟4和5依次添加所有的Feature到當前圖層即可

代碼實現

下面的例子中,我們讀取GeoJSON表示的中國省區數據,然后其轉為Shapefile格式。

GeoJSON編碼片段如下:

如何創建Shapefile文件并寫入數據

可以看到每個Feature都有一個properties字段和geometry字段,我們需要根據properties字段的信息創建Shapefile數據的屬性表,根據geometry字段創建Shapefile中的幾何數據。

from osgeo import ogr
from osgeo import osr
import json
import os
os.environ['SHAPE_ENCODING'] = "utf-8"


with open('China.json') as f:
 china = json.load(f)

# 創建DataSource
driver = ogr.GetDriverByName('ESRI Shapefile')
ds = driver.CreateDataSource('China.shp')

# 創建WGS84空間參考
srs = osr.SpatialReference()
srs.ImportFromEPSG(4326)

# 創建圖層
layer = ds.CreateLayer('province', srs, ogr.wkbPolygon)
# 添加屬性定義
fname = ogr.FieldDefn('Name', ogr.OFTString)
fname.SetWidth(24)
layer.CreateField(fname)
fcx = ogr.FieldDefn('CenterX', ogr.OFTReal)
layer.CreateField(fcx)
fcy = ogr.FieldDefn('CenterY', ogr.OFTReal)
layer.CreateField(fcy)

# 變量GeoJSON中的features
for f in china['features']:
 # 新建Feature并且給其屬性賦值
 feature = ogr.Feature(layer.GetLayerDefn())
 feature.SetField('Name', f['properties']['name'])
 feature.SetField('CenterX', f['properties']['cp'][0])
 feature.SetField('CenterY', f['properties']['cp'][1])

 # 設置Feature的幾何屬性Geometry
 polygon = ogr.CreateGeometryFromJson(str(f['geometry']))
 feature.SetGeometry(polygon)
 # 創建Feature
 layer.CreateFeature(feature)
 del feature
ds.FlushCache()

del ds

關于“如何創建Shapefile文件并寫入數據”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

桦川县| 宝兴县| 都兰县| 洛隆县| 枣强县| 新乡市| 东乌| 申扎县| 南木林县| 武邑县| 米泉市| 腾冲县| 西安市| 永定县| 平谷区| 泽普县| 阜宁县| 宕昌县| 凌海市| 普兰县| 永清县| 佛山市| 肇源县| 常宁市| 荣昌县| 石林| 客服| 临泉县| 日照市| 万载县| 武城县| 金坛市| 东乌珠穆沁旗| 修文县| 凌云县| 黔江区| 高青县| 福州市| 深州市| 犍为县| 根河市|