10.shpfile读取数据之js-shapefile.js

基于shapefile.js读取shp文件

话不多说,先上代码后上图

	var fs=getDataByShp(function(features){
		console.log(features)
	})
	
function getDataByShp(success){
 var features=[];
shapefile.open("./geospark/city.shp")
  .then(source => source.read()
    .then(function log(result) {
      if (result.done) {
      	success(features);
      }else{
      	features.push(result.value);
     	 return source.read().then(log);
      }
      
    })) .catch(error => console.error(error.stack));
}

更改编码

可直接在shapefile.js源码中更改

function open(shp$$1, dbf$$1, options) {
  if (typeof dbf$$1 === "string") {
    if (!/\.dbf$/.test(dbf$$1)) dbf$$1 += ".dbf";
    dbf$$1 = path(dbf$$1, options);
  } else if (dbf$$1 instanceof ArrayBuffer || dbf$$1 instanceof Uint8Array) {
    dbf$$1 = array(dbf$$1);
  } else if (dbf$$1 != null) {
    dbf$$1 = stream(dbf$$1);
  }
  if (typeof shp$$1 === "string") {
    if (!/\.shp$/.test(shp$$1)) shp$$1 += ".shp";
    if (dbf$$1 === undefined) dbf$$1 = path(shp$$1.substring(0, shp$$1.length - 4) + ".dbf", options).catch(function() {});
    shp$$1 = path(shp$$1, options);
  } else if (shp$$1 instanceof ArrayBuffer || shp$$1 instanceof Uint8Array) {
    shp$$1 = array(shp$$1);
  } else {
    shp$$1 = stream(shp$$1);
  }
  return Promise.all([shp$$1, dbf$$1]).then(function(sources) {
    var shp$$1 = sources[0], dbf$$1 = sources[1], encoding = "gbk";//"utf-8";
    if (options && options.encoding != null) encoding = options.encoding;
    return shapefile(shp$$1, dbf$$1, dbf$$1 && new TextDecoder(encoding));
  });
}

读取结果:
在这里插入图片描述

好的,以下是一个使用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、付费专栏及课程。

余额充值