ArcEngine批量添加XY数据

使用ArcGIS Desktop “添加XY数据”或者“创建XY事件图层”工具 可以导入Excel坐标数据,生成临时图层并添加至ArcMap、ArcGlobe或者ArcScene中。在ArcEngine中可以利用GP工具(MakeXYEventLayer)将某个 x,y 坐标表添加到地图、globe 或 scene 中。该数据表中必须包含两个字段:一个用于 x 坐标,一个用于 y 坐标。Excel表的表头最好字段放至第一行,否则会报错。原本想直接将MakeXYEventLayer创建事件图层添加至地图中,但是至今未想到方法。只有暂时生成要素类导出至磁盘中,再添加至地图中。如果高手们有其他方法,希望不吝赐教。

实现思路: 
第一步:读取Excel数据表,提取表名、X字段、Y字段 
第二步:实例化数据管理工具MakeXYEventLayer 
第三步:实例化Geoprocessor,并执行数据管理工具MakeXYEventLayer 
第四步:使用复制要素工具将此事件图层导出为磁盘上的要素类 
第五步:加载要素至图层中 
主要代码如下:

GP执行MakeXYEventLayer工具并复制图层至文件地理数据库中

/// <summary>

/// 执行MakeXYEventLayer工具,并将创建的临时图层转换为要素类

/// </summary>

/// <param
name="xyEventLayer">XY 事件图层tool</param>

/// <param
name="out_Layer_Path">要素输出路径</param>

/// <returns></returns>

private IFeatureClass ConvertExcelToFeatureClass(MakeXYEventLayer
xyEventLayer, string
out_Layer_Path)

{

try

{

Geoprocessor GP = new Geoprocessor();

GP.OverwriteOutput =
true;

GP.Execute(xyEventLayer, null);//执行XY事件

//复制要素

ESRI.ArcGIS.DataManagementTools.CopyFeatures cf = new ESRI.ArcGIS.DataManagementTools.CopyFeatures();

cf.in_features =
xyEventLayer.out_layer;

cf.out_feature_class
= out_Layer_Path + xyEventLayer.out_layer;

IGeoProcessorResult
gpResult = GP.Execute(cf, null) as IGeoProcessorResult;

IFeatureClass
_featureClass;

IQueryFilter qf;//查询过滤

IGPUtilities gpUtils
= new
GPUtilitiesClass();

gpUtils.DecodeFeatureLayer(gpResult.GetOutput(0), out _featureClass, out qf);

IFeatureCursor
cursor = featureClass.Insert(true);

return _featureClass;

}

catch (Exception ex)

{

MessageBox.Show("导入要素失败,原因:" + ex.ToString());

return null;

}

}

调用方法,并将要素添加至地图中

//比如Excel文件:大学校区.xls,表包括(sheet1,sheet2,sheet2)

//tableName即表路径,该路径形式例如:D:\\DataFile\\大学校区.xls\\sheet1$

tableName =
m_fileName + "\\" + comtxt_excel.SelectedItem.ToString();

x = comtxt_x.SelectedItem.ToString();//X坐标

y = comtxt_y.SelectedItem.ToString();//Y坐标

outName =
txt_layername.Text;

//添加XY事件

MakeXYEventLayer
MxyLayer = new MakeXYEventLayer(tableName, x, y, outName);

string tempPath =
GetAppDirectory() + "TempData\\Temp.gdb\\";//要素临时存储路径

featureClass =
ConvertExcelToFeatureClass(MxyLayer, tempPath);

if (featureClass != null)

{

pFeatureLater =
new FeatureLayerClass();

pFeatureLater.FeatureClass = featureClass;

pFeatureLater.Name = featureClass.AliasName;

axMapControl1.Map.AddLayer(pFeatureLater as ILayer);

axMapControl1.Extent = axMapControl1.FullExtent;

}

时间: 2024-07-28 19:14:46

ArcEngine批量添加XY数据的相关文章

ASP.NET MVC用存储过程批量添加修改数据

用Entity Framework 进行数据库交互,在代码里直接用lamda表达式和linq对数据库操作,中间为程序员省去了数据库访问的代码时间,程序员直接可以专注业务逻辑层的编写.但是对于比较复杂的表关系关联查询或者修改就比较费劲了.通常可以采用的方式是用EF执行SQL语句或者"存储过程",特别是执行复杂批量任务,当然也可以在MVC底层用ADO.NET,这里就不多说了.怎么做批量呢?这里讲讲在EF下用存储过程批量添加修改数据. 需求是这样的:需要批量添加修改产品类别的投放任务数额,每

mysql+php+pdo批量添加大数据

1.使用insert into插入 ini_set('max_execution_time','0');//限制超时时间,因为第一种时间较长,索性设为0不限制 $pdo = new PDO("mysql:host=localhost;dbname=oradt_cloud1520","root","123456");  for($i=0; $i<100000; $i++){ $str = strrand(32); $pdo -> exe

CI 框架批量添加数据(如果数据库有就更新数据)

model: public function insert_select($values) { $sql = 'INSERT INTO ' . $this->_table_name . '(article_id,user_id,share_link,short_link,read_price,created_at,updated_at) VALUES ' . $values . ' ON DUPLICATE KEY UPDATE article_id=values(article_id),use

Yii2如何批量添加数据

批量添加这个操作,在实际开发中经常用得到,今天小编抽空给大家整理些有关yii2批量添加的问题,感兴趣的朋友一起看看吧. 在上篇文章给大家介绍了关于浅析Yii2 gridview实现批量删除教程,当然,着重点在于怎么去操作gridview了,今儿我们来好好谈谈yii2如何批量添加数据? 有同学嚷嚷了,这还不简单,我foreach一循环,每个循环里面直接把数据插入到数据库,简单粗暴完事!我擦嘞,哥,你要是跟我在一个公司,我觉得第二天见到你的概率可就不大了! 话不多说,说多了你在骂我,我们步入正题,先

EF批量添加数据性能慢的问题的解决方案

//EF批量添加数据性能慢的问题的解决方案 public ActionResult BatchAdd() { using (var db = new ToneRoad.CEA.DbContext.DbContext()) { //**********************第一种解决方案 直接使用sql********************** string sqls = ""; for (int i = 0; i < 100000; i++) { sqls += "

.Net中批量添加数据的几种实现方法比较

在.Net中经常会遇到批量添加数据,如将Excel中的数据导入数据库,直接在DataGridView控件中添加数据再保存到数据库等等. 方法一:一条一条循环添加 通常我们的第一反应是采用for或foreach循环一条一条的添加. for (int i = 0; i < dgv.Rows.Count; i++) { string sql = "insert into ....."; SqlHelper.ExcuteNonQuery(CommandType.Text, sql, nu

在条码打印软件上如何添加背景图并批量打印可变数据

在条码标签打印软件上我们制作产品标签或者防伪标签的时候,一般导入图片都是通过位图或者矢量图来实现的,那么除了这两种,还有没有其他方法呢?今天就来给大家介绍另外一种方法,那就是通过添加背景图片的方式来导入图片,这种方法使用起来也是比较方便的,操作也比较简单,具体操作方法如下所示:1. 首先打开条码标签打印软件,新建纸张,设置纸张和标签的尺寸2. 点击上方的文档设置,弹出文档设置对话框,在文档设置画布对话框中我们勾选背景图片及打印背景,并根据提示点浏览,选择我们需要的图片打开,然后点确定,就可以看到

ADO.NET批量添加数据到SQL Server—BulkCopy使用指南

BulkCopy位于System.Data.SqlClient命名空间,允许你使用其他源的数据有效地批量加载 SQL Server 表. 属性: BatchSize :每个批处理中的行数. 在每个批处理结束时,批处理中的行将发送到服务器. BulkCopyTimeout:超时之前可用于完成操作的秒数. ColumnMappings:返回 SqlBulkCopyColumnMapping 项的集合. 列映射定义数据源中的列和目标中的列之间的关系. DestinationTableName:服务器上

SSM批量添加数据

如何应对面临批量数据时如何提交给后台 方式1: 使用JSON格式 后台功能接受实现使用@ResponseBody 前端当有多行数据的时候添加到一个数组再通过JSON格式到后台List接收 @RequestMapping(value = "/emp01",method = RequestMethod.POST, produces = "application/json") @ResponseBody public String empAdd02(@RequestBod