12.shpfile读取数据之java-gadl

本文介绍了如何使用Java的GDAL库来处理.shp文件,包括打开数据源、获取图层信息、字段定义和遍历要素等操作。
摘要由CSDN通过智能技术生成

基于java gadl库读取shp文件

话不多说,先上代码


import org.gdal.ogr.DataSource;
import org.gdal.ogr.Driver;
import org.gdal.ogr.Feature;
import org.gdal.ogr.FieldDefn;
import org.gdal.ogr.Layer;
import org.gdal.ogr.ogr;
public class ShpReader {
    public static void main(String[] args) {
        // 注册GDAL库
        ogr.RegisterAll();
        // 打开数据源
        DataSource dataSource = ogr.Open("D:\\gisdata\\geospark\\city.shp");
        // 获取图层数量
        int layerCount = dataSource.GetLayerCount();
        System.out.println("Layer count: " + layerCount);
        // 获取第一个图层
        Layer layer = dataSource.GetLayer(0);
        // 获取要素数量
        int featureCount = layer.GetFeatureCount();
        System.out.println("Feature count: " + featureCount);
        // 获取字段信息
        int fieldCount = layer.GetLayerDefn().GetFieldCount();
        for (int i = 0; i < fieldCount; i++) {
            FieldDefn fieldDefn = layer.GetLayerDefn().GetFieldDefn(i);
            System.out.println("Field name: " + fieldDefn.GetName());
            System.out.println("Field type: " + fieldDefn.GetFieldTypeName(fieldDefn.GetFieldType()));
            System.out.println("Field width: " + fieldDefn.GetWidth());
            System.out.println("Field precision: " + fieldDefn.GetPrecision());
        }
        // 遍历要素
        Feature feature = null;
        while ((feature = layer.GetNextFeature()) != null) {
            System.out.println("Feature ID: " + feature.GetFID());
            System.out.println("Geometry type: " + feature.GetGeometryRef().GetGeometryName());
            System.out.println("Geometry coordinates: " + feature.GetGeometryRef().ExportToWkt());
            for (int i = 0; i < fieldCount; i++) {
                FieldDefn fieldDefn = layer.GetLayerDefn().GetFieldDefn(i);
                System.out.println(fieldDefn.GetName() + ": " + feature.GetFieldAsString(i));
            }
            feature.delete();
        }
        // 释放资源
        dataSource.delete();
    }
}
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
好的,以下是一个使用GDAL读取Shpfile数据的C++代码示例: ```c++ #include "gdal/gdal_priv.h" #include "gdal/cpl_conv.h" int main() { GDALAllRegister(); // 注册所有驱动程序 // 打开Shapefile文件 GDALDataset* dataset = (GDALDataset*)GDALOpenEx("test.shp", GDAL_OF_VECTOR, NULL, NULL, NULL); if (dataset == NULL) { printf("Open shapefile failed!\n"); return 1; } // 获取图层数量 int layerCount = dataset->GetLayerCount(); printf("Layer count: %d\n", layerCount); // 获取第一个图层 OGRLayer* layer = dataset->GetLayer(0); // 获取要素数量 int featureCount = layer->GetFeatureCount(); printf("Feature count: %d\n", featureCount); // 遍历所有要素 OGRFeature* feature = nullptr; layer->ResetReading(); while ((feature = layer->GetNextFeature()) != NULL) { // 获取要素的几何形状 OGRGeometry* geometry = feature->GetGeometryRef(); if (geometry != NULL) { OGRwkbGeometryType geometryType = geometry->getGeometryType(); printf("Geometry Type: %s\n", OGRGeometryTypeToName(geometryType)); } // 获取要素的属性 OGRFeatureDefn* featureDefn = layer->GetLayerDefn(); for (int i = 0; i < featureDefn->GetFieldCount(); i++) { OGRFieldDefn* fieldDefn = featureDefn->GetFieldDefn(i); printf("%s: %s\n", fieldDefn->GetNameRef(), feature->GetFieldAsString(i)); } OGRFeature::DestroyFeature(feature); } // 关闭数据集 GDALClose(dataset); return 0; } ``` 这个示例代码使用GDAL的C++ API打开Shpfile文件,获取第一个图层,遍历所有要素,输出每个要素的几何形状和属性。需要注意的是,为了使用GDAL的C++ API,需要添加GDAL头文件,并链接GDAL库。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

紫雪giser

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值