使用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;

}

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

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

    用Entity Framework 进行数据库交互,在代码里直接用lamda表达式和linq对数据库操作,中间为程序员省去了数据库访问的代码时间,程序员直接可以专注业务逻辑层的编写.但是对于比较复杂的 ...

  2. spring MVC 后端 接收 前端 批量添加的数据(简单示例)

    第一种方式:(使用ajax的方式) 前端代码: <%@ page contentType="text/html;charset=UTF-8" language="j ...

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

    1.使用insert into插入 ini_set('max_execution_time','0');//限制超时时间,因为第一种时间较长,索性设为0不限制 $pdo = new PDO(" ...

  4. Arcgis10.3在添加XY数据时出现问题

    准备通过excel表格(xls格式)中的经纬度生成点数据,但是选择数据的时候报错:连接到数据库失败,常规功能故障,外部表不是预期的格式.如下图所示: 解决方法: 将xls格式的表格另存为csv格式,重 ...

  5. 前端JS批量添加校验数据唯一性

    <script type="text/javascript"> //维护删除数组中的某一项 Array.prototype.remove = function(val) ...

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

    model: public function insert_select($values) { $sql = 'INSERT INTO ' . $this->_table_name . '(ar ...

  7. mybatis 批量将list数据插入到数据库

    随着业务需要,有时我们需要将数据批量添加到数据库,mybatis提供了将list集合循环添加到数据库的方法.具体实现代码如下: 1.mapper层中创建 insertForeach(List < ...

  8. myBatis批量添加实例

    <!-- 批量添加中转地数据 -->      <insert id="addBatch" parameterType="com.isoftstone. ...

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

    //EF批量添加数据性能慢的问题的解决方案 public ActionResult BatchAdd() { using (var db = new ToneRoad.CEA.DbContext.Db ...

随机推荐

  1. 局部变量&&malloc函数&&生命周期的一些见解

    最近在温习指针的部分时发现了一个有趣的问题,先看以下程序: //1.c #include<stdio.h> int* fun() { int t = 567; return &t; ...

  2. SQL起别名

    select列的时候取别名有三种方法,这三种方法并不是所有数据库都适用. 方法一.直接在字段名称后面加上别名,中间以空格隔开. 方法二.以as关键字指定字段别名,as在select的字段和别名之间. ...

  3. 关于Android 打开新的Activity 虚拟键盘的弹出与不弹出

    关于Android 打开新的Activity 虚拟键盘的弹出与不弹出 打开Activity 时  在相应的情况 弹出虚拟键盘 或者 隐藏虚拟键盘 会给用户非常好的用户体验 , 实现起来也比较简单 只需 ...

  4. SQL查询一个月第一天/最后一天及日期格式化

    1.一个月第一天的Select DATEADD(mm, DATEDIFF(mm,0,getdate()), 0) 2.本周的星期一Select DATEADD(wk, DATEDIFF(wk,0,ge ...

  5. Android sdk tool android 命令参数

      命令参数说明: $ ./android --? Error: Flag '--?' is not a valid global flag. Did you mean to specify it a ...

  6. problem during schema create,statement create sequence act_evt_log_seq

    今天在调试程序的时候出现"problem during schema create,statement create sequence act_evt_log_seq"这个错误,跟 ...

  7. C#中的继承

    按照我个人的理解,继承和实现接口不是一个概念,结构和类型都可以实现接口,枚举不能. 话说,结构可以继承吗? 先梳理一下C#中的继承关系,如下图: class => [BaseClass => ...

  8. Programming in Lua读书笔记

         Lua的长处之一就是可以通过新类型和函数来扩展其功能.动态类型检查最大限度允许多态出现,并自动简化调用内存管理的接口,因为这样不需要关心谁来分配内存谁来释放内存,也不必担心数据溢出.高级函数 ...

  9. ajaxpro返回值类型总结-DataTable(转)

    ajaxpro使用总结系列其他内容 ajaxpro ajaxmethod 重载调用问题 ajaxpro方法ajaxmethod调用示例 ajaxpro返回值类型总结-string,int ajaxpr ...

  10. 慕课网-Java入门第一季-6-7 使用 Arrays 类操作 Java 中的数组

    来源:http://www.imooc.com/code/1556 Arrays 类是 Java 中提供的一个工具类,在 java.util 包中.该类中包含了一些方法用来直接操作数组,比如可直接实现 ...