news 2026/3/17 19:30:48

GIS 数据转换:使用 GDAL 将 TXT 转换为 Shp 数据

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
GIS 数据转换:使用 GDAL 将 TXT 转换为 Shp 数据

前言

TXT 作为一种文本格式,可以很方便的存储一些简单几何数据。在 GIS 开发中,经常需要进行数据的转换处理,其中常见的便是将 TXT 转换为 Shp 数据进行展示。

本篇教程在之前一系列文章的基础上讲解

如如果你还没有看过,建议从以上内容开始。

1. 开发环境

本文使用如下开发环境,以供参考。

时间:2025年

系统:Windows 11

Python:3.11.7

GDAL:3.11.1

2. 数据准备

TXT(纯文本文件)是一种最基本的文件格式,仅存储无格式的文本数据,适用于各种场景(如数据交换、日志记录、配置文件等)。

如下是全国省会城市人口 TXT 文本结构:

ID,Name,Longitude,Latitude,Population
1,Beijing,116.40,39.90,2171万
2,Shanghai,121.47,31.23,2487万
3,Guangzhou,113.26,23.12,1868万
4,Shenzhen,114.05,22.55,1756万
5,Tianjin,117.20,39.08,1373万
6,Chongqing,106.50,29.53,3205万
7,Chengdu,104.06,30.67,2094万
8,Wuhan,114.30,30.60,1121万
9,Hangzhou,120.15,30.28,1194万
10,Nanjing,118.78,32.04,931万
11,Xi'an,108.93,34.27,1295万
12,Changsha,112.97,28.20,839万
13,Zhengzhou,113.62,34.75,1260万
14,Harbin,126.63,45.75,1076万
15,Shenyang,123.43,41.80,831万
16,Qingdao,120.38,36.07,1007万
17,Dalian,121.62,38.92,745万
18,Xiamen,118.08,24.48,516万
19,Ningbo,121.55,29.88,854万
20,Hefei,117.28,31.86,937万
21,Fuzhou,119.30,26.08,829万
22,Jinan,117.00,36.67,920万
23,Taiyuan,112.55,37.87,530万
24,Changchun,125.35,43.88,906万
25,Kunming,102.72,25.04,846万
26,Nanning,108.37,22.82,874万
27,Lanzhou,103.82,36.06,435万
28,Yinchuan,106.27,38.47,285万
29,Xining,101.77,36.62,263万
30,Urümqi,87.62,43.82,405万
31,Lhasa,91.11,29.65,86万
32,Haikou,110.20,20.05,287万

3. 导入依赖

TXT作为一种矢量数据格式,可以使用矢量库OGR进行处理,以实现TXT数据从文本格式转换为Shp格式。其中还涉及坐标定义,所以还需要引入osr模块。

from osgeo import ogr,osr
import os
import csv

4. 数据读取与转换

定义一个方法Txt2Shp(txtPath,shpPath,encoding="UTF-8")用于将TXT数据转换为Shp数据。

"""
说明:将 TXT 文件转换为 Shapfile 文件
参数:
-txtPath:TXT 文件路径
-shpPath:Shp 文件路径
-encoding:TXT 文件编码
"
""
def Txt2Shp(txtPath,shpPath,encoding="UTF-8")

在进行TXT数据格式转换之前,需要检查数据路径是否存在。

# 检查文件是否存在
ifos.path.exists(txtPath):
print("TXT 文件存在。")
else:
print("TXT 文件不存在,请重新选择文件!")
return

通过GetDriverByName获取Shp数据驱动,并使用os.path.exists方法检查Shp文件是否已经创建,如果存在则将其删除。

# 注册所有驱动
ogr.RegisterAll()

# 添加Shp数据源
shpDriver = ogr.GetDriverByName('ESRI Shapefile')

ifos.path.exists(shpPath):
try:
shpDriver.DeleteDataSource(shpPath)
print("文件已删除!")
except Exception as e:
print(f"文件删除出错:{e}")
returnFalse

接着创建Shp数据源和空间参考,数据坐标系这里定义为4326。

# 创建Shp数据源
shpDataSource = shpDriver.CreateDataSource(shpPath)
ifshpDataSource is None:
print("无法创建Shp数据源,请检查文件!")
returnfalse
# 创建空间参考
spatialReference = osr.SpatialReference()
spatialReference.ImportFromEPSG(4326)

之后通过数据源方法CreateLayer创建Shp图层,使用图层方法CreateField添加属性字段,需要定义属性名称以及属性字段类型。

# 创建图层
shpLayer = shpDataSource.CreateLayer("points",spatialReference,ogr.wkbPoint)

# 添加图层字段
shpLayer.CreateField(ogr.FieldDefn("ID",ogr.OFTString))
shpLayer.CreateField(ogr.FieldDefn("Name",ogr.OFTString))
shpLayer.CreateField(ogr.FieldDefn("Longitude",ogr.OFTReal))
shpLayer.CreateField(ogr.FieldDefn("Latitude",ogr.OFTReal))
shpLayer.CreateField(ogr.FieldDefn("Population",ogr.OFTString))

读取TXT数据并将其转换为Shapefile数据,在打开数据时,根据TXT文件属性,使用逗号分隔符进行读取并跳过表头行数据。之后根据行数据进行属性遍历,将读取的字段值和几何属性写入到要素对象中。

# 读取TXT文件
with open(txtPath,"r",encoding=encoding) as txtFile:
# 根据逗号分隔符进行读取
reader = csv.reader(txtFile,delimiter=",")
# 跳过表头
header = next(reader)
# 遍历记录
forrowinreader:
print(f"要素记录:{row}")
# 创建要素
feature = ogr.Feature(shpLayer.GetLayerDefn())

# 根据图层字段写入属性
feature.SetField("ID",str(row[0]))
feature.SetField("Name",str(row[1]))
feature.SetField("Longitude",float(row[2]))
feature.SetField("Latitude",float(row[3]))
feature.SetField("Population",str(row[4]))

# 创建几何对象
wkt = f"POINT({float(row[2])} {float(row[3])})"
pointGeom = ogr.CreateGeometryFromWkt(wkt)

feature.SetGeometry(pointGeom)

# 将要素添加到图层
shpLayer.CreateFeature(feature)
feature = None

CreateCpgFile2Encode(shpPath,encoding)
# 释放数据资源
shpDataSource = None

其中CreateCpgFile2Encode方法用于创建字符编码文件,后缀名为.cpg

"""
说明:创建.cpg文件指定字符编码
参数:
-shpPath:Shp文件路径
-encoding:Shp文件字符编码
"
""
def CreateCpgFile2Encode(shpPath,encoding):
fileName = os.path.splitext(shpPath)[0]
cpgFile = fileName +".cpg"

with open(cpgFile,"w",encoding=encoding) as f:
f.write(encoding)
print(f"成功创建编码文件: {cpgFile}")

程序成功转换数据显示如下:

使用ArcMap打开显示结果如下:

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/15 19:23:15

LangFlow中的广告文案生成:高转化率内容批量产出

LangFlow中的广告文案生成:高转化率内容批量产出 在数字营销的战场上,一条精准、抓人的广告文案,可能就是转化率翻倍的关键。但现实是,企业每天要为成百上千个商品、活动、渠道准备不同的文案,靠人工撰写不仅耗时耗力&…

作者头像 李华
网站建设 2026/3/15 19:23:10

设置中心-Cordovaopenharmony统一配置入口

一、功能概述 应用的各种配置项(如单位选择、提醒时间、数据保留期限等)需要一个统一的管理入口。"设置中心"模块提供了一个集中的配置界面,让用户可以方便地调整应用行为。本篇文章围绕"设置中心"展开,介绍如…

作者头像 李华
网站建设 2026/3/15 19:23:12

LangFlow中的FAQ自动回答器:企业知识库高效利用

LangFlow中的FAQ自动回答器:企业知识库高效利用 在企业日常运营中,员工和客户常常面临大量重复性问题的咨询——“年假怎么申请?”、“报销流程是什么?”、“产品常见故障如何处理?”……这些问题虽然简单,…

作者头像 李华
网站建设 2026/3/15 19:23:11

Topit终极Mac窗口置顶工具:彻底告别窗口遮挡烦恼

Topit终极Mac窗口置顶工具:彻底告别窗口遮挡烦恼 【免费下载链接】Topit Pin any window to the top of your screen / 在Mac上将你的任何窗口强制置顶 项目地址: https://gitcode.com/gh_mirrors/to/Topit 在当今多任务并行的数字工作环境中,Mac…

作者头像 李华
网站建设 2026/3/16 1:59:04

编写驱动设备函数的用法

从终端输出和文件信息来看,已经编译成功了(生成了 RK3568 平台对应的 ARM64 架构驱动模块)。一、编译成功的核心依据make过程完成了CC(编译)、MODPOST(模块符号处理)、LD(链接&#…

作者头像 李华