欢迎您来到GIS动力
在做一般的数据处理时,要想得到某字段唯一值,我们可以利用 SQL 语言之关键字 Distinct 方便地获得。但是在用 AE 作开发时,我们应该怎样去做呢?当然我们可以首先获得某个字段的所有值,然后再去比较、提取、获得唯一值。这样的工作写起来麻烦,效率也非常低。其实 AE 类库 ESRI.ArcGIS.Geodatabase 之接口 IDataStatistics 已为我们提供了这样的方法。 ArcGIS 开发帮助文档有很多示例,大都都是用 VB 或是 VBA 编写,下面是本人利用 C#+AE9.1 编写的示例: 1 /**/ /// <summary> 2 /// 得到要素类某字段的唯一值 3 /// </summary> 4 /// <param name="pFeatureClass"> 要素类 </param> 5 /// <param name="strFld"> 指定要得到唯一值的字段 </param> 6 /// <returns> 唯一值字符数据 </returns> 7 public static string [] GetUniqueValue(IFeatureClass pFeatureClass, string strFld) 8 { 9 // 得到IFeatureCursor游标 10 IFeatureCursor pCursor = pFeatureClass.Search( null , false ); 11 12 // coClass对象实例生成 13 IDataStatistics pData = new DataStatisticsClass(); 14 pData.Field = strFld; 15 pData.Cursor = pCursor as ICursor; 16 17 // 枚举唯一值 18 IEnumerator pEnumVar = pData.UniqueValues ; 19 20 // 记录总数 21 int RecordCount = pData.UniqueValueCount; 22 23 // 字符数组 24 string [] strValue = new string [RecordCount]; 25 pEnumVar.Reset(); 26 27 int i = 0 ; 28 29 while (pEnumVar.MoveNext()) 30 { 31 strValue[ ++ i] = pEnumVar.Current.ToString(); 32 } 33 34 return strValue; 35 } 1 /**/ /// <summary> 2 /// 得到要素类某字段的唯一值 3 /// </summary> 4 /// <param name="pFeatureClass"> 要素类 </param> 5 /// <param name="strFld"> 指定要得到唯一值的字段 </param> 6 /// <returns> 唯一值字符数据 </returns> 7 public static string [] GetUniqueValue(IFeatureClass pFeatureClass, string strFld) 8 { 9 // 得到IFeatureCursor游标 10 IFeatureCursor pCursor = pFeatureClass.Search( null , false ); 11 12 // coClass对象实例生成 13 IDataStatistics pData = new DataStatisticsClass(); 14 pData.Field = strFld; 15 pData.Cursor = pCursor as ICursor; 16 17 // 枚举唯一值 18 IEnumerator pEnumVar = pData.UniqueValues ; 19 20 // 记录总数 21 int RecordCount = pData.UniqueValueCount; 22 23 // 字符数组 24 string [] strValue = new string [RecordCount]; 25 pEnumVar.Reset(); 26 27 int i = 0 ; 28 29 while (pEnumVar.MoveNext()) 30 { 31 strValue[ ++ i] = pEnumVar.Current.ToString(); 32 } 33 34 return strValue; 35 } 9 7 3 1 2 3 4 5 6 7 8 9 10 4 8 :
ArcGIS 开发帮助文档有很多示例,大都都是用 VB 或是 VBA 编写,下面是本人利用 C#+AE9.1 编写的示例: 1 /**/ /// <summary> 2 /// 得到要素类某字段的唯一值 3 /// </summary> 4 /// <param name="pFeatureClass"> 要素类 </param> 5 /// <param name="strFld"> 指定要得到唯一值的字段 </param> 6 /// <returns> 唯一值字符数据 </returns> 7 public static string [] GetUniqueValue(IFeatureClass pFeatureClass, string strFld) 8 { 9 // 得到IFeatureCursor游标 10 IFeatureCursor pCursor = pFeatureClass.Search( null , false ); 11 12 // coClass对象实例生成 13 IDataStatistics pData = new DataStatisticsClass(); 14 pData.Field = strFld; 15 pData.Cursor = pCursor as ICursor; 16 17 // 枚举唯一值 18 IEnumerator pEnumVar = pData.UniqueValues ; 19 20 // 记录总数 21 int RecordCount = pData.UniqueValueCount; 22 23 // 字符数组 24 string [] strValue = new string [RecordCount]; 25 pEnumVar.Reset(); 26 27 int i = 0 ; 28 29 while (pEnumVar.MoveNext()) 30 { 31 strValue[ ++ i] = pEnumVar.Current.ToString(); 32 } 33 34 return strValue; 35 } 1 /**/ /// <summary> 2 /// 得到要素类某字段的唯一值 3 /// </summary> 4 /// <param name="pFeatureClass"> 要素类 </param> 5 /// <param name="strFld"> 指定要得到唯一值的字段 </param> 6 /// <returns> 唯一值字符数据 </returns> 7 public static string [] GetUniqueValue(IFeatureClass pFeatureClass, string strFld) 8 { 9 // 得到IFeatureCursor游标 10 IFeatureCursor pCursor = pFeatureClass.Search( null , false ); 11 12 // coClass对象实例生成 13 IDataStatistics pData = new DataStatisticsClass(); 14 pData.Field = strFld; 15 pData.Cursor = pCursor as ICursor; 16 17 // 枚举唯一值 18 IEnumerator pEnumVar = pData.UniqueValues ; 19 20 // 记录总数 21 int RecordCount = pData.UniqueValueCount; 22 23 // 字符数组 24 string [] strValue = new string [RecordCount]; 25 pEnumVar.Reset(); 26 27 int i = 0 ; 28 29 while (pEnumVar.MoveNext()) 30 { 31 strValue[ ++ i] = pEnumVar.Current.ToString(); 32 } 33 34 return strValue; 35 } 9 7 3 1 2 3 4 5 6 7 8 9 10 4 8 :
1 /**/ /// <summary> 2 /// 得到要素类某字段的唯一值 3 /// </summary> 4 /// <param name="pFeatureClass"> 要素类 </param> 5 /// <param name="strFld"> 指定要得到唯一值的字段 </param> 6 /// <returns> 唯一值字符数据 </returns> 7 public static string [] GetUniqueValue(IFeatureClass pFeatureClass, string strFld) 8 { 9 // 得到IFeatureCursor游标 10 IFeatureCursor pCursor = pFeatureClass.Search( null , false ); 11 12 // coClass对象实例生成 13 IDataStatistics pData = new DataStatisticsClass(); 14 pData.Field = strFld; 15 pData.Cursor = pCursor as ICursor; 16 17 // 枚举唯一值 18 IEnumerator pEnumVar = pData.UniqueValues ; 19 20 // 记录总数 21 int RecordCount = pData.UniqueValueCount; 22 23 // 字符数组 24 string [] strValue = new string [RecordCount]; 25 pEnumVar.Reset(); 26 27 int i = 0 ; 28 29 while (pEnumVar.MoveNext()) 30 { 31 strValue[ ++ i] = pEnumVar.Current.ToString(); 32 } 33 34 return strValue; 35 } 1 /**/ /// <summary> 2 /// 得到要素类某字段的唯一值 3 /// </summary> 4 /// <param name="pFeatureClass"> 要素类 </param> 5 /// <param name="strFld"> 指定要得到唯一值的字段 </param> 6 /// <returns> 唯一值字符数据 </returns> 7 public static string [] GetUniqueValue(IFeatureClass pFeatureClass, string strFld) 8 { 9 // 得到IFeatureCursor游标 10 IFeatureCursor pCursor = pFeatureClass.Search( null , false ); 11 12 // coClass对象实例生成 13 IDataStatistics pData = new DataStatisticsClass(); 14 pData.Field = strFld; 15 pData.Cursor = pCursor as ICursor; 16 17 // 枚举唯一值 18 IEnumerator pEnumVar = pData.UniqueValues ; 19 20 // 记录总数 21 int RecordCount = pData.UniqueValueCount; 22 23 // 字符数组 24 string [] strValue = new string [RecordCount]; 25 pEnumVar.Reset(); 26 27 int i = 0 ; 28 29 while (pEnumVar.MoveNext()) 30 { 31 strValue[ ++ i] = pEnumVar.Current.ToString(); 32 } 33 34 return strValue; 35 } 9 7 3 1 2 3 4 5 6 7 8 9 10 4 8 :
1 /**/ /// <summary> 2 /// 得到要素类某字段的唯一值 3 /// </summary> 4 /// <param name="pFeatureClass"> 要素类 </param> 5 /// <param name="strFld"> 指定要得到唯一值的字段 </param> 6 /// <returns> 唯一值字符数据 </returns> 7 public static string [] GetUniqueValue(IFeatureClass pFeatureClass, string strFld) 8 { 9 // 得到IFeatureCursor游标 10 IFeatureCursor pCursor = pFeatureClass.Search( null , false ); 11 12 // coClass对象实例生成 13 IDataStatistics pData = new DataStatisticsClass(); 14 pData.Field = strFld; 15 pData.Cursor = pCursor as ICursor; 16 17 // 枚举唯一值 18 IEnumerator pEnumVar = pData.UniqueValues ; 19 20 // 记录总数 21 int RecordCount = pData.UniqueValueCount; 22 23 // 字符数组 24 string [] strValue = new string [RecordCount]; 25 pEnumVar.Reset(); 26 27 int i = 0 ; 28 29 while (pEnumVar.MoveNext()) 30 { 31 strValue[ ++ i] = pEnumVar.Current.ToString(); 32 } 33 34 return strValue; 35 } 9 7 3 1 2 3 4 5 6 7 8 9 10 4 8 :
滇ICP备05006901号