C++ GDAL添加shpfile字段

2021/10/26 20:40:11

本文主要是介绍C++ GDAL添加shpfile字段,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

#include <iostream>
#include <ogrsf_frmts.h>
#include <ctime>
using namespace std;

int main()
{
	//支持中文路径
	CPLSetConfigOption("GDAL_FILENAME_IS_UTF8", "NO");
	//支持属相表中文字符
	CPLGetConfigOption("SHAPE_ENCODING", "UTF-8");
	//注册所有驱动
	GDALAllRegister();
	const char * shppath = "Supermarket.shp";
	GDALDataset * ds = (GDALDataset *)GDALOpenEx(shppath, GDAL_OF_VECTOR and GDAL_OF_UPDATE, NULL, NULL, NULL);
	if (ds == NULL)
	{
		cout << "Failed to open shapefile!" << endl;
		return 0;
	}
	OGRLayer * lyr = ds->GetLayer(0);
	if (lyr == NULL)
	{
		cout << "Failed to get shape layer!" << endl;
		return 0;
	}
	OGRFieldDefn * fieldDefn = new OGRFieldDefn("money", OFTInteger);
	lyr->CreateField(fieldDefn);
	srand((int)time(NULL));
	while (true)
	{
		OGRFeature * feature = lyr->GetNextFeature();
		if (feature == NULL)
		{
			break;
		}
		int money = rand() % 100;
		feature->SetField("money", money);
		lyr->SetFeature(feature);
		OGRFeature::DestroyFeature(feature);
	}
	GDALClose(ds);
	cout << "finished!" << endl;
	return 0;
}


这篇关于C++ GDAL添加shpfile字段的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程