在.Net6中用gdal实现第一个功能

目录

一、创建.NET6的控制台应用程序

二、加载Gdal插件

三、编写程序


一、创建.NET6的控制台应用程序

二、加载Gdal插件

Gdal的资源可以经过NuGet包引入。右键单击项目名称,然后选择 "Manage NuGet Packages"(管理 NuGet 包)。NuGet 包管理器窗口将打开,可以搜索和浏览可用的 NuGet 包。主要有下面几个:

1)GDAL 包:这是 GDAL(Geospatial Data Abstraction Library)的主要包,它提供了访问和处理各种地理空间数据格式的功能。GDAL 包包含了 GDAL 的核心库以及相关的文件和资源。

2)GDAL.Native 包:这是 GDAL 的本地(Native)包,它包含了 GDAL 的本地二进制文件,用于与底层操作系统进行交互。这些本地二进制文件是与特定操作系统和架构相关的,因此 GDAL.Native 包通常会根据不同的操作系统和架构提供不同的包版本。

3)GDAL.Plugins 包:这是 GDAL 的插件(Plugins)包,它包含了一些额外的插件文件,用于提供对某些特定数据格式或功能的支持。这些插件可以扩展 GDAL 的能力,使其能够读取和处理更多的地理空间数据格式或执行特定的空间数据操作。

三、编写程序

本次只引入了GDAL.Native包来实现一个简单的shp读取功能。

写好代码后运行,不出意外报错了:显示没有找到模块。(:Unable to load DLL 'ogr_wrap' or one of its dependencies: 找不到指定的模块)

​​​​​​​

这是需要去软件运行目录下的gdal文件夹中找对应平台的资源放到外层运行目录下:

动态库放好之后继续运行代码,这是报错消失了,不过数据并没有读取到。

这是因为没有注册驱动,注册驱动后在运行,可以读取到数据了:

​​​​​​​

全部代码:

cs 复制代码
static void ReadShpLayer()
{
    OSGeo.OGR.Ogr.RegisterAll(); // 注册所有的驱动
    string shpFilePath = @"D:\GDAL\data\Point.shp";
    DataSource ds = Ogr.Open(shpFilePath, 0);//0表示只读,1表示可修改  
    if (ds == null) { Console.WriteLine("打开文件【{0}】失败!", shpFilePath); return; }
    // 获取第一个图层
    int iLayerCount = ds.GetLayerCount();
    Layer oLayer = ds.GetLayerByIndex(0);
    long fcount= oLayer.GetFeatureCount(0); //获取要素数量
    if (oLayer == null) { Console.WriteLine("获取第{0}个图层失败! n", "0"); return; }
}
相关推荐
MasterNeverDown14 小时前
.net 微服务jeager链路跟踪
微服务·架构·.net
喵叔哟1 天前
51.【.NET8 实战--孢子记账--从单体到微服务--转向微服务】--新增功能--登录注册扩展
数据库·微服务·.net
时光追逐者1 天前
.NET 使用 CsvHelper 快速读取和写入 CSV 文件
c#·.net·.net core·csv
界面开发小八哥1 天前
文档控件DevExpress Office File API v25.1新本亮点:重磅升级各类API
c#·.net·界面控件·devexpress·ui开发
追逐时光者2 天前
.NET 使用 CsvHelper 快速读取和写入 CSV 文件
后端·.net
Kookoos2 天前
差分隐私在运营指标:ABP 的 DP 计数器与噪声预算
.net·差分隐私·abp vnext·拉普拉斯机制·隐私预算
蒋星熠3 天前
.NET技术深度解析:现代企业级开发指南
人工智能·python·深度学习·微服务·ai·性能优化·.net
我是唐青枫4 天前
从 Skip Take 到 Keyset:C# 分页原理与实践
开发语言·c#·.net
用户3721574261354 天前
告别手动复制粘贴:C# 实现 Excel 与 TXT 文本文件高效互转
c#·.net
忧郁的蛋~4 天前
在.NET标准库中进行数据验证的方法
后端·c#·asp.net·.net·.netcore