亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

如何創建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

高清| 福建省| 凌源市| 东阿县| 文化| 合江县| 稷山县| 杂多县| 九江市| 普兰县| 武平县| 东兰县| 罗甸县| 大港区| 白城市| 化隆| 鹤岗市| 武冈市| 凯里市| 南郑县| 沿河| 健康| 社会| 泸西县| 宜宾市| 凤山县| 泗阳县| 溧阳市| 平泉县| 元阳县| 郯城县| 长春市| 大关县| 多伦县| 安多县| 健康| 石城县| 乌鲁木齐县| 吴桥县| 崇明县| 获嘉县|