GDB中创建要素数据集

简介:

转自 在geodatabase中创建要素集

 

复制代码
//在数据集中创建要素

private void menuItem25_Click(object sender, System.EventArgs e)

{

CreateFClassInPDB(@"C:\ArcGIS\ArcTutor\BuildingaGeodatabase\Montgomery.mdb");

}

public static void CreateFClassInPDB(string filePath){

string shapeFieldName="shape";

IFeatureWorkspace pFWS;

try

{

pFWS=openPDB(filePath);

//IEnumDataset pDatasets;

//pDatasets=pWS.get_Datasets(esriDatasetType.esriDTFeatureDataset);

IFeatureDataset pFeatureDataset=pFWS.OpenFeatureDataset("Water");

//MessageBox.Show(pFeatureDataset.Name);

// IDataset pDataset=pDatasets.Next();

// IFeatureDataset pFeatureDataset=pDataset as IFeatureDataset;

IGeoDataset pGeoDataset=pFeatureDataset as IGeoDataset;

IFields pFields = null;

IFieldsEdit pFieldsEdit = null;

pFields = new FieldsClass();

pFieldsEdit=pFields as IFieldsEdit;

pFieldsEdit.FieldCount_2=2;

IField pField = null;

IFieldEdit pFieldEdit = null;

//Make the shape field it will need a geometry definition, with a spatial reference

pField=new FieldClass();

pFieldEdit=pField as IFieldEdit;

pFieldEdit.Name_2=shapeFieldName;

pFieldEdit.Type_2=esriFieldType.esriFieldTypeGeometry;

IGeometryDef pGeomDef = null;

IGeometryDefEdit pGeomDefEdit = null;

pGeomDef = new GeometryDefClass();

pGeomDefEdit =pGeomDef as IGeometryDefEdit;

pGeomDefEdit.GeometryType_2=esriGeometryType.esriGeometryPolygon;

pGeomDefEdit.SpatialReference_2=pGeoDataset.SpatialReference;//get the spatial reference

pFieldEdit.GeometryDef_2=pGeomDefEdit;

//pFieldsEdit.AddField(pField);

pFieldsEdit.set_Field(0,pField);

//Add another miscellaneous text field

pField = new FieldClass();

pFieldEdit = pField as IFieldEdit;

pFieldEdit.Length_2=30;

pFieldEdit.Name_2="TextField";

pFieldEdit.Type_2=esriFieldType.esriFieldTypeString;

//pFieldsEdit.AddField(pField);

pFieldsEdit.set_Field(1,pField);

//pFeatureDataset.CreateFeatureClass("test",pFields,null,null,esriFeatureType.esriFTSimple,"Shape","");

UID pUID;

pUID = new UIDClass();

pUID.Value="esriGeoDatabase.Feature";

//pFeatureDataset.CreateFeatureClass("test",pFields,pUID,null,esriFeatureType.esriFTSimple,"Shape","");

pFeatureDataset.CreateFeatureClass("test",pFields,pUID,null,esriFeatureType.esriFTSimple,"Shape","");

MessageBox.Show("创建成功");

}

catch(Exception e){

MessageBox.Show(e.Message);

}

}

//创建shapefile文件

public static void createShapeFile(String folderName,String shapeName){

if(folderName==""||shapeName=="") return;

string shapeFieldName="shape";

try

{

IFeatureWorkspace pFWS = null;

IWorkspaceFactory pWorkspaceFactory = null;

pWorkspaceFactory = new Shapef

ileWorkspaceFactoryClass();

//if(pWorkspaceFactory.IsWorkspace(folderName)==false) return;

pFWS=pWorkspaceFactory.OpenFromFile(folderName,0) as IFeatureWorkspace;

IFields pFields = null;

IFieldsEdit pFieldsEdit = null;

pFields = new FieldsClass();

pFieldsEdit=pFields as IFieldsEdit;

IField pField = null;

IFieldEdit pFieldEdit = null;

//Make the shape field it will need a geometry definition, with a spatial reference

pField=new FieldClass();

pFieldEdit=pField as IFieldEdit;

pFieldEdit.Name_2=shapeFieldName;

pFieldEdit.Type_2=esriFieldType.esriFieldTypeGeometry;

IGeometryDef pGeomDef = null;

IGeometryDefEdit pGeomDefEdit = null;

pGeomDef = new GeometryDefClass();

pGeomDefEdit =pGeomDef as IGeometryDefEdit;

pGeomDefEdit.GeometryType_2=esriGeometryType.esriGeometryPolygon;

pGeomDefEdit.SpatialReference_2=new UnknownCoordinateSystemClass();

pFieldEdit.GeometryDef_2=pGeomDefEdit;

pFieldsEdit.AddField(pField);

//Add another miscellaneous text field

pField = new FieldClass();

pFieldEdit = pField as IFieldEdit;

pFieldEdit.Length_2=30;

pFieldEdit.Name_2="TextField";

pFieldEdit.Type_2=esriFieldType.esriFieldTypeString;

pFieldsEdit.AddField(pField);

IFeatureClass pFeatClass = null;

pFeatClass = pFWS.CreateFeatureClass(shapeName, pFields, null, null,esriFeatureType.esriFTSimple, shapeFieldName, "");

MessageBox.Show("名为"+shapeName+"的shape文件创建成功");

}

catch(Exception e){

MessageBox.Show(e.Message);

}

} 
复制代码

 

没有整理与归纳的知识,一文不值!高度概括与梳理的知识,才是自己真正的知识与技能。 永远不要让自己的自由、好奇、充满创造力的想法被现实的框架所束缚,让创造力自由成长吧! 多花时间,关心他(她)人,正如别人所关心你的。理想的腾飞与实现,没有别人的支持与帮助,是万万不能的。




    本文转自wenglabs博客园博客,原文链接:http://www.cnblogs.com/arxive/p/6655669.html ,如需转载请自行联系原作者


相关实践学习
阿里云图数据库GDB入门与应用
图数据库(Graph Database,简称GDB)是一种支持Property Graph图模型、用于处理高度连接数据查询与存储的实时、可靠的在线数据库服务。它支持Apache TinkerPop Gremlin查询语言,可以帮您快速构建基于高度连接的数据集的应用程序。GDB非常适合社交网络、欺诈检测、推荐引擎、实时图谱、网络/IT运营这类高度互连数据集的场景。 GDB由阿里云自主研发,具备如下优势: 标准图查询语言:支持属性图,高度兼容Gremlin图查询语言。 高度优化的自研引擎:高度优化的自研图计算层和存储层,云盘多副本保障数据超高可靠,支持ACID事务。 服务高可用:支持高可用实例,节点故障迅速转移,保障业务连续性。 易运维:提供备份恢复、自动升级、监控告警、故障切换等丰富的运维功能,大幅降低运维成本。 产品主页:https://www.aliyun.com/product/gdb
相关文章
|
搜索推荐 Linux Python
VET:一个基于R语言的VCF数据提取工具,支持按基因ID、物理位置、样品名称提取指定变异信息
VET:一个基于R语言的VCF数据提取工具,支持按基因ID、物理位置、样品名称提取指定变异信息
|
2月前
|
数据采集 Python
Python实用记录(七):通过retinaface对CASIA-WebFace人脸数据集进行清洗,并把错误图路径放入txt文档
使用RetinaFace模型对CASIA-WebFace人脸数据集进行清洗,并将无法检测到人脸的图片路径记录到txt文档中。
43 1
|
4月前
|
人工智能 JSON 自然语言处理
PaddleNLP UIE -- 药品说明书信息抽取(名称、规格、用法、用量)
PaddleNLP UIE -- 药品说明书信息抽取(名称、规格、用法、用量)
64 5
|
2月前
|
数据可视化 算法 Python
基于OpenFOAM和Python的流场动态模态分解:从数据提取到POD-DMD分析
本文介绍了如何利用Python脚本结合动态模态分解(DMD)技术,分析从OpenFOAM模拟中提取的二维切片数据,以深入理解流体动力学现象。通过PyVista库处理VTK格式的模拟数据,进行POD和DMD分析,揭示流场中的主要能量结构及动态特征。此方法为研究复杂流动系统提供了有力工具。
81 2
基于OpenFOAM和Python的流场动态模态分解:从数据提取到POD-DMD分析
|
3月前
|
数据采集
基于R语言的GD库实现地理探测器并自动将连续变量转为类别变量
【9月更文挑战第9天】在R语言中,可通过`gd`包实现地理探测器。首先,安装并加载`gd`包;其次,准备包含地理与因变量的数据框;然后,使用`cut`函数将连续变量转换为分类变量;最后,通过`gd`函数运行地理探测器,并打印结果以获取q值等统计信息。实际应用时需根据数据特点调整参数。
150 8
|
4月前
|
自然语言处理 数据处理 知识图谱
PaddleNLP UIE 实体关系抽取 -- 抽取药品说明书(名称、规格、用法、用量)【废弃】
PaddleNLP UIE 实体关系抽取 -- 抽取药品说明书(名称、规格、用法、用量)【废弃】
51 1
|
6月前
|
机器学习/深度学习 人工智能 监控
人工智能平台PAI产品使用合集之设置了7个特征,但在最后生成的数据表中只包含了6个id_feature的特征,是什么导致的
阿里云人工智能平台PAI是一个功能强大、易于使用的AI开发平台,旨在降低AI开发门槛,加速创新,助力企业和开发者高效构建、部署和管理人工智能应用。其中包含了一系列相互协同的产品与服务,共同构成一个完整的人工智能开发与应用生态系统。以下是对PAI产品使用合集的概述,涵盖数据处理、模型开发、训练加速、模型部署及管理等多个环节。
|
7月前
|
存储 机器学习/深度学习 数据可视化
Python面板时间序列数据预测:格兰杰因果关系检验Granger causality test药品销售实例与可视化
Python面板时间序列数据预测:格兰杰因果关系检验Granger causality test药品销售实例与可视化
|
7月前
|
机器学习/深度学习 算法 数据可视化
统计建模——模型——python为例
统计建模——模型——python为例
296 0
|
7月前
|
编解码 定位技术 Python
Python中ArcPy实现ArcGIS自动批量制图与地图要素批量设置
Python中ArcPy实现ArcGIS自动批量制图与地图要素批量设置
187 1