Python 根据数据模板创建shapefile的实现

 更新时间:2019年11月26日 11:16:15   作者:staHuri  
今天小编就为大家分享一篇Python 根据数据模板创建shapefile的实现,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

废话不多说,我就直接上代码让大家看看吧!

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @File : copyShapefile.py
# @Author: huifer
# @Date : 2018-4-28
from os.path import exists

import gdal

from osgeo import ogr
from os import remove

gdal.SetConfigOption("GDAL_FILENAME_IS_UTF8", "YES") # 路径中文
gdal.SetConfigOption("SHAPE_ENCODING", "GBK") # 属性中文
in_shapefile = "dataSample/wang_point.shp"# 数据模板
out_shapefile = "shapefileAa.shp" # 输出数据集
in_ds = ogr.Open(in_shapefile) # 读取模板数据
in_lyr = in_ds.GetLayerByIndex(0)
if exists(out_shapefile):
  remove(out_shapefile)
drv = ogr.GetDriverByName("ESRI Shapefile") # 指定数据驱动
out_ds = drv.CreateDataSource(out_shapefile) # 创建数据源
proj = in_lyr.GetSpatialRef() # 获取模板坐标系
out_lyr = out_ds.CreateLayer(out_shapefile.split(".")[0], proj, ogr.wkbPoint)
# copy the schema of the original shapefile to the destination shapefile
lyr_def = in_lyr.GetLayerDefn()
for i in range(lyr_def.GetFieldCount()): # 获取字段长度
  out_lyr.CreateField(lyr_def.GetFieldDefn(i)) # 创建字段
  feature = ogr.Feature(lyr_def)
  wkt = "POINT(88615.730000 75345.486000)"
  point = ogr.CreateGeometryFromWkt(wkt)
  feature.SetGeometry(point)
  # 添加点
  out_lyr.CreateFeature(feature)
  # 关闭 特征
  feature = None
  # 关闭数据
data_source = None

以上这篇Python 根据数据模板创建shapefile的实现就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • python判断端口是否打开的实现代码

    python判断端口是否打开的实现代码

    python判断端口是否打开的代码,有需要的朋友可以参考下
    2013-02-02
  • python应用程序在windows下不出现cmd窗口的办法

    python应用程序在windows下不出现cmd窗口的办法

    这篇文章主要介绍了python应用程序在windows下不出现cmd窗口的办法,适用于python写的GTK程序并用py2exe编译的情况下,需要的朋友可以参考下
    2014-05-05
  • 详解如何使用Python操作MySQL的各种功能和用法

    详解如何使用Python操作MySQL的各种功能和用法

    当今互联网时代,数据处理已经成为了一个非常重要的任务,而MySQL作为一款开源的关系型数据库,被广泛应用于各种场景,本篇博客将介绍如何使用Python操作MySQL的各种功能,以及一些高级用法,需要的朋友可以参考下
    2023-11-11
  • PyTorch Distributed Data Parallel使用详解

    PyTorch Distributed Data Parallel使用详解

    这篇文章主要为大家介绍了PyTorch Distributed Data Parallel使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • python中子类与父类的关系基础知识点

    python中子类与父类的关系基础知识点

    在本篇文章里小编给大家整理的是一篇关于python中子类与父类的关系基础知识点内容,对此有兴趣的朋友们可以学习下。
    2021-02-02
  • 详解python中文编码问题

    详解python中文编码问题

    一直以来python中文编码是个及其头大的问题,需要好好学习下,我用python为例,简单介绍下python编程时如何处理好中文编码的问题,感兴趣的朋友们可以参考下
    2021-06-06
  • python列表删除和多重循环退出原理详解

    python列表删除和多重循环退出原理详解

    这篇文章主要介绍了python列表删除和多重循环退出原理详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-03-03
  • selenium判断元素是否存在的两种方法小结

    selenium判断元素是否存在的两种方法小结

    这篇文章主要介绍了selenium判断元素是否存在的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • Python socket服务常用操作代码实例

    Python socket服务常用操作代码实例

    这篇文章主要介绍了Python socket服务常用操作代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-06-06
  • Python实现根据日期获取当天凌晨时间戳的方法示例

    Python实现根据日期获取当天凌晨时间戳的方法示例

    这篇文章主要介绍了Python实现根据日期获取当天凌晨时间戳的方法,涉及Python针对日期与时间戳的相关转换、运算等操作技巧,需要的朋友可以参考下
    2019-04-04

最新评论