基于GDAL的点数据保存

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
简介:

保存数据的第一步是要把数据解析出来,然后根据GDAL的规则进行数据point类型的shapefile数据生成。大概步骤为:

一、定义保存点要素数据的类

这里定义了两个基类:

//基类,保存要素类型,点、线、面
class Element
{
private:	
	char Type;
	int Code;
public:
	Element(void);
	~Element(void);
	void setType(char Type);
	char getType();	
	void setCode(int Code);
	int getCode();
};

//基类,保存要素中点的XY坐标
class Geometry
{
private:
	double X;
	double Y;
public:
	Geometry(void);
	~Geometry(void);
	void setX(double X);
	double getX();
	void setY(double Y);
	double getY();
};

点数据的类定义为:

#include "Element.h"
#include "Geometry.h"
#include<string>
using std::string;


//单个POI数据结构
//根据PAS文件中对数据描述构建
//Name为POI名字
//PinYin为POI名字拼音
//Code为POI编码
//categoryCode为POI图层类别码
class SPoint :
	public Geometry,public Element
{
private:
	char *Name;
	char *PinYin;
	//int Code;
	int CategoryCode;		
public:
	SPoint(void);	
	~SPoint(void);

	void setName(char *Name);
	char* getName();
	void setPinYin(char *PinYin);
	char *getPinYin();
	//void setCode(int Code);
	//int getCode();
	void setCategoryCode(int CategoryCode);
	int getCategoryCode();	
};


在保存点数据时,定义一个List集合

list<SPoint> mPoint;

二、原始数据解析

这一口根据情况不同方法也不同,有解析shapefile的,有解析mapinfo数据的,也有直接解析二进制数据的。鄙人是直接解析二进制数据。由于工作性质和数据安全性原因,这一步就省略。

三、数据保存

定义GDAL驱动,根据GDAL规则来保存shapefile数据。

//保存点数据
void savePoint()
{
	mPolygon.clear();
	mPolyline.clear();

	char *FilePath = "E:\\data\\point.shp";

	//判断文件是否存在,不存在就进行下面的保存操作,存在就先删除再保存
	fstream f;
	f.open(FilePath,ios::in);
	//文件不存
	if(!f)
	{
		f.close();
		//remove(FilePath);
	}
	//文件存在,删除文件
	else
	{
		f.close();
		remove(FilePath);
	}

	//要保存的shapefile文件名,只保存文件名,不保存路径和.shp
	char FileName[20];  
	char *p=strrchr(FilePath,'\\')+1;
	strcpy(FileName,p);
	int i=0,j=0;
	while(i< 20 &&FileName[i]!='\0' &&FileName[i]!='.')
		i++;
	if(i !=20) FileName[i]='\0';

	//注册OGR所有驱动
	GDALAllRegister();
	OGRRegisterAll();

	CPLSetConfigOption("GDAL_FILENAME_IS_UTF8","NO");
	CPLSetConfigOption("SHAPE_ENCODING","CP936");

	//定义驱动
	const char *pszDriverName = "ESRI Shapefile";
	OGRSFDriver *poDriver;
	poDriver = OGRSFDriverRegistrar::GetRegistrar()->GetDriverByName(pszDriverName );
	if( poDriver == NULL )
	{
		printf( "%s 驱动不可用.\n", pszDriverName );
		return;
	}

	//创建filepath路径的文件
	OGRDataSource *poDS;
	poDS = poDriver->CreateDataSource( FilePath, NULL );
	if( poDS == NULL )
	{
		printf( "创建文件s%失败.\n",FilePath );
		return;
	}


	//定义图层,点图层
	OGRLayer *poLayer;
	poLayer = poDS->CreateLayer(FileName, NULL, wkbPoint, NULL );
	if( poLayer == NULL )
	{
		printf( "创建图层失败.\n" );
		return;
	}

	//创建属性字段
	//定义属性字段code、type和name
	OGRFieldDefn codeField("code", OFTInteger );
	OGRFieldDefn typeField("type", OFTString );
	OGRFieldDefn nameField("name", OFTString );
	//设置code和type字段的宽度
	codeField.SetWidth(32);
	typeField.SetWidth(32);
	nameField.SetWidth(100);

	//创建字段
	if( poLayer->CreateField( &codeField ) != OGRERR_NONE )
	{
		printf( "创建字段codeField失败.\n" );
		return;
	}
	if( poLayer->CreateField( &typeField ) != OGRERR_NONE )
	{
		printf( "创建字段codeField失败.\n" );
		return;
	}
	if( poLayer->CreateField( &nameField ) != OGRERR_NONE )
	{
		printf( "创建字段name失败.\n" );
		return;
	}

		
	list<SPoint>::iterator itor;
	
	for (itor = mPoint.begin();itor != mPoint.end();itor++)
	{
			//创建第i个点
			OGRFeature *poFeature=OGRFeature::CreateFeature( poLayer->GetLayerDefn());

			//设置第i条线的属性
			poFeature->SetField("code",itor->getCode());		
			poFeature->SetField("type", itor->getType());		
			poFeature->SetField("name", itor->getName());
		
			//定义Point,并设置其XY坐标
			OGRPoint *poPoint = new OGRPoint();		
			poPoint->setX(itor->getX());
			poPoint->setY(itor->getY());

			poFeature->SetGeometry(poPoint);
			
			if( poLayer->CreateFeature( poFeature ) != OGRERR_NONE )
			{
				printf( "创建point失败.\n" );
				return;
			}
			
			OGRFeature::DestroyFeature( poFeature );
	}
	OGRDataSource::DestroyDataSource( poDS );
	
}





相关文章
|
数据库
psc文件文件如何导入数据库
psc文件文件如何导入数据库
212 0
|
存储 Java 定位技术
gis利器之Gdal(二)shp数据读取
本文首先简单介绍了空间数据shp数据的基本知识,其常见的文件组成形式。使用qgis软件对数据进行常规预览,最后重点介绍了使用gdal对矢量信息进行读取,​包括空间信息和属性信息
1329 0
gis利器之Gdal(二)shp数据读取
|
C# C++
GDAL打开中文路径和读写中文字段的问题
版权声明:欢迎评论和转载,转载请注明来源。 https://blog.csdn.net/zy332719794/article/details/40394839 GDAL不同的版本对中文的默认支持不一,有时候默认支持,有时候需要自己去设置。
1781 0
|
5月前
|
计算机视觉 Windows Python
windows下使用python + opencv读取含有中文路径的图片 和 把图片数据保存到含有中文的路径下
在Windows系统中,直接使用`cv2.imread()`和`cv2.imwrite()`处理含中文路径的图像文件时会遇到问题。读取时会返回空数据,保存时则无法正确保存至目标目录。为解决这些问题,可以使用`cv2.imdecode()`结合`np.fromfile()`来读取图像,并使用`cv2.imencode()`结合`tofile()`方法来保存图像至含中文的路径。这种方法有效避免了路径编码问题,确保图像处理流程顺畅进行。
458 1
|
5月前
|
SQL JSON 关系型数据库
n种方式教你用python读写excel等数据文件
n种方式教你用python读写excel等数据文件
76 1
|
8月前
|
存储 Java
Java环境下使用CsvReader()读取CSV文件
Java环境下使用CsvReader()读取CSV文件
|
7月前
|
IDE 开发工具 Python
使用python3遍历文件夹并将文件目录保存到指定文件
使用python3遍历文件夹并将文件目录保存到指定文件
|
8月前
|
数据采集 存储 人工智能
Python采集数据保存CSV文件内容乱码解决
Python采集数据保存CSV文件内容乱码解决
103 1
|
API C++ Python
Fiona简介及Shapefile数据读取
用GDAL的Python绑定API书写程序有没有一种仍然在写C/C++的感觉,Fiona基于GDAL提供了更加Pythonic的读取空间矢量数据的API,参见:http://toblerity.org/fiona/index.html
123 0
|
缓存 计算机视觉
OpenCv读取中文路径
OpenCv读取中文路径
237 0