news 2026/4/23 13:48:25

使用命令行工具 ogr2ogr 将 CSV 转换为 Shp 数据(二)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
使用命令行工具 ogr2ogr 将 CSV 转换为 Shp 数据(二)

前言

ogr2ogr是一个数据转换工具,可用于在文件格式之间转换简单要素数据。它还可以在转换过程中执行各种操作,如空间或属性选择、减少属性集、设置输出坐标系,甚至在转换过程中重新投影特征。

如有兴趣,可参阅文章:

GDAL 实现将 CSV 转换为 Shp 数据(一)[1]

ogr2ogr作为GDAL(Geospatial Data Abstraction Library)库中的一个命令行工具,用于转换和处理地理空间数据。它可以读取多种矢量数据格式(如Shapefile、GeoJSON、KML、GML、PostGIS等),并进行格式转换、坐标转换、属性过滤、几何操作等。

1. 用户环境

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

时间:2025年

系统:Windows 11

Python:3.11.7

GDAL:3.11.1

ogr2ogr:3.9.2

2. 验证ogr2ogr工具信息

打开命令行终端,输入命令ogr2ogr --version查看版本信息。如果ogr2ogr正确安装并添加到环境变量,便会输出其版本号。

3. 将CSV转换为Shp数据

原始CSV数据内容显示如下,具有四个字段,分别为“名称”、“地址”、“LATQ”代表纬度,“LNGQ”代表经度。

在命令行终端输入以下命令进行数据转换。

ogr2ogr -f"ESRI Shapefile"E:datatest_dataogr_transform.shp E:datatest_data景点.csv -oo X_POSSIBLE_NAMES=LNGQ,longitude,x,X -oo Y_POSSIBLE_NAMES=LATQ,latitude,y,Y -a_srs EPSG:4326

以下是ogr2ogr工具常用参数解释:

选项

说明

-f "ESRI Shapefile"

指定输出格式,如“ESRI Shapefile”

-a_srs EPSG:4326

设置空间参考

-select "field1,field2"

选择特定字段

-where "value > 100"

过滤条件

-lco ENCODING=UTF-8

设置字符编码

-oo AUTODETECT_TYPE=YES

自动检测字段类型

-oo SEPARATOR=TAB

设置分隔符(TAB/COMMA/SEMICOLON)

-oo X_POSSIBLE_NAMES

指定经度字段,可书写多个可能值

-oo Y_POSSIBLE_NAMES

指定纬度字段,可书写多个可能值

4. 中文转换错误解决办法

由于CSV文件中具有中文字段,直接进行转换工具会报错,无法创建中文字段。此时需要指定正确的字符编码。

在命令中添加-lco ENCODING=UTF-8选项以正确转换中文字符。

ogr2ogr -f"ESRI Shapefile"E:datatest_dataogr_transform.shp E:datatest_data景点.csv -oo X_POSSIBLE_NAMES=LNGQ,longitude,x,X -oo Y_POSSIBLE_NAMES=LATQ,latitude,y,Y -lco ENCODING=UTF-8 -a_srs EPSG:4326

将CSV转换为Shp数据在ArcGIS中的显示结果。

5. 常见字符编码

以下是一些常见编码格式。

# UTF-8(推荐)
-lco ENCODING=UTF-8

# 中文编码
-lco ENCODING=GBK# 简体中文
-lco ENCODING=BIG5# 繁体中文
-lco ENCODING=GB2312# 简体中文旧版

# 其他编码
-lco ENCODING=LATIN1
-lco ENCODING=ISO-8859-1
-lco ENCODING=CP1252

6. 数据转换事项

使用ogr2ogr工具进行数据转换时如果所有的命令都写在一行,那么显示效果不仅不美观,也不具有可读性,所以可按照转换内容对其进行分行展示。在windowslinux系统中换行符略有差别。

windows系统进行分行展示时使用符号"^"进行分隔:

ogr2ogr -f"ESRI Shapefile""E:\datatest_data\ogr_transform5.shp""E:\data\test_data\景点.csv"^
-oo X_POSSIBLE_NAMES=LNGQ,longitude,x,X ^
-oo Y_POSSIBLE_NAMES=LATQ,latitude,y,Y ^
-lco ENCODING=UTF-8 ^
-a_srs EPSG:4326

linux系统进行分行展示时使用符号"\"进行分隔

ogr2ogr -f"ESRI Shapefile""E:\datatest_data\ogr_transform5.shp""E:\data\test_data\景点.csv"^
-oo X_POSSIBLE_NAMES=LNGQ,longitude,x,X ^
-oo Y_POSSIBLE_NAMES=LATQ,latitude,y,Y ^
-lco ENCODING=UTF-8 ^
-a_srs EPSG:4326
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 10:48:30

10 个AI论文工具,助力继续教育学员高效写作!

10 个AI论文工具,助力继续教育学员高效写作! AI 工具的崛起,让学术写作更高效 在当前继续教育的背景下,越来越多的学员需要面对论文写作这一重要任务。无论是本科、硕士还是博士阶段,论文的撰写都是一项耗时且复杂的工…

作者头像 李华
网站建设 2026/4/23 10:48:27

Flutter:构建高性能跨平台应用的现代框架

标题:Flutter:构建高性能跨平台应用的现代框架 引言 在移动应用开发领域,开发者始终面临一个核心挑战:如何以最少的资源和时间,为多个平台(如 iOS 和 Android)构建高质量、一致体验的应用。传统…

作者头像 李华
网站建设 2026/4/23 13:45:07

深入理解Go语言errors.As方法:灵活的错误类型识别

引言 在Go语言中,错误处理是一个核心话题。Go 1.13引入了新的错误处理机制,包括错误包裹(error wrapping)和几个相关的工具函数。其中errors.As函数是一个非常有用但可能被忽视的工具,它允许我们在错误链中查找特定类型…

作者头像 李华
网站建设 2026/4/23 12:14:59

9个AI论文工具,自考本科轻松搞定!

9个AI论文工具,自考本科轻松搞定! AI 工具如何助力自考论文写作 在当前的学术环境中,越来越多的学生开始借助 AI 工具来提升论文写作效率。对于自考生而言,时间紧张、任务繁重是常态,而 AI 工具的出现则为他们提供了强…

作者头像 李华
网站建设 2026/4/23 12:23:51

Redis 如何应对大数据高并发访问挑战

Redis如何应对大数据高并发访问挑战:从原理到实践的深度解析 摘要 在电商秒杀、实时推荐、分布式缓存等高并发场景中,传统关系型数据库(如MySQL)因磁盘IO瓶颈、连接数限制等问题,无法满足每秒数万甚至数十万次的请求需…

作者头像 李华
网站建设 2026/4/23 12:22:31

Java线程的三种创建方式

目录 1.线程的概念 2.进程和线程的对比 3.线程创建的三种方式 1)继承Thread类 2)实现Runnable接口 3)实现Callable接口 三种方法的执行流程 1.线程的概念 线程是程序执行流的最小单位,是进程中的一个独立执行单元。一个进程可以包含多个线程,这些…

作者头像 李华