创建Shapefile文件并写入数据的例子


Posted in Python onNovember 26, 2019

基本思路

使用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文件并写入数据的例子就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python的类实例属性访问规则探讨
Jan 30 Python
python获取局域网占带宽最大3个ip的方法
Jul 09 Python
使用PyV8在Python爬虫中执行js代码
Feb 16 Python
关于python pyqt5安装失败问题的解决方法
Aug 08 Python
Python基础语言学习笔记总结(精华)
Nov 14 Python
教你用 Python 实现微信跳一跳(Mac+iOS版)
Jan 04 Python
微信跳一跳python辅助软件思路及图像识别源码解析
Jan 04 Python
解决TensorFlow训练内存不断增长,进程被杀死问题
Feb 05 Python
基于python-pptx库中文文档及使用详解
Feb 14 Python
python shapely.geometry.polygon任意两个四边形的IOU计算实例
Apr 12 Python
keras 自定义loss model.add_loss的使用详解
Jun 22 Python
pandas:get_dummies()与pd.factorize()的用法及区别说明
May 21 Python
python使用opencv在Windows下调用摄像头实现解析
Nov 26 #Python
使用Python实现 学生学籍管理系统
Nov 26 #Python
python redis 批量设置过期key过程解析
Nov 26 #Python
python3 tkinter实现添加图片和文本
Nov 26 #Python
使用Rasterio读取栅格数据的实例讲解
Nov 26 #Python
Python小程序之在图片上加入数字的代码
Nov 26 #Python
基于Python获取城市近7天天气预报
Nov 26 #Python
You might like
PHP简洁函数(PHP简单明了函数语法)
2012/06/10 PHP
Laravel如何使用Redis共享Session
2018/02/23 PHP
thinkPHP5框架实现多数据库连接,跨数据连接查询操作示例
2019/05/29 PHP
json-lib出现There is a cycle in the hierarchy解决办法
2010/02/24 Javascript
extjs tabpanel限制选项卡数量实现思路及代码
2013/04/02 Javascript
等待指定时间后自动跳转或关闭当前页面的js代码
2013/07/09 Javascript
制作jquery遮罩层效果导航菜单代码分享
2013/12/25 Javascript
PHP PDO操作总结
2014/11/17 Javascript
JavaScript 事件对象介绍
2015/04/13 Javascript
jQuery获取页面及个元素高度、宽度的总结——超实用
2015/07/28 Javascript
JavaScript实现点击单元格改变背景色的方法
2016/02/12 Javascript
bootstrap手风琴制作方法详解
2017/01/11 Javascript
VUE中v-model和v-for指令详解
2017/06/23 Javascript
Javascript刷新页面的实例
2017/09/23 Javascript
10分钟彻底搞懂Http的强制缓存和协商缓存(小结)
2018/08/30 Javascript
jQuery实现的别踩白块小游戏完整示例
2019/01/07 jQuery
读懂CommonJS的模块加载
2019/04/19 Javascript
Vue 如何使用props、emit实现自定义双向绑定的实现
2020/06/05 Javascript
基于p5.js 2D图像接口的扩展(交互实现)
2020/11/30 Javascript
详解实现vue的数据响应式原理
2021/01/20 Vue.js
[00:35]可解锁地面特效
2018/12/20 DOTA
介绍Python的@property装饰器的用法
2015/04/28 Python
Python判断值是否在list或set中的性能对比分析
2016/04/16 Python
浅谈python import引入不同路径下的模块
2017/07/11 Python
Python基于高斯消元法计算线性方程组示例
2018/01/17 Python
Python实现批量压缩图片
2018/01/25 Python
Python利用itchat库向好友或者公众号发消息的实例
2019/02/21 Python
numba提升python运行速度的实例方法
2021/01/25 Python
一款纯css3实现的鼠标经过按钮特效教程
2014/11/09 HTML / CSS
大一期末自我鉴定
2013/12/13 职场文书
2015中学教学工作总结
2015/07/22 职场文书
2016年五一劳动节专题校园广播稿
2015/12/17 职场文书
2019已经过半,你知道年中工作总结该怎么写吗?
2019/07/03 职场文书
MySQL update set 和 and的区别
2021/05/08 MySQL
教你用Python matplotlib库制作简单的动画
2021/06/11 Python
关于Oracle12C默认用户名system密码不正确的解决方案
2021/10/16 Oracle