GeoProcessing中通过GP.GetMessage(2)捕捉异常

Sub MappingFields()

On Error GoTo EH:

  '//initialize license
  Dim aoi As IAoInitialize
  Set aoi = New AoInitialize
  aoi.Initialize esriLicenseProductCodeArcInfo
 
  Dim GP As IGeoProcessor
  Set GP = New GeoProcessor
  GP.OverwriteOutput = True

  Dim strTableA As String
  strTableA = "C:"Temp"VBTests"FieldMapping"citiblocks.gdb"census"
 
  Dim pDataElement As IDataElement
  Dim pDETableA As IDETable
 
  Dim pGPU As IGPUtilities
  Set pGPU = New GPUtilities
 
  Set pDataElement = pGPU.MakeDataElement(strTableA, Nothing, Nothing)
  Set pDETableA = pDataElement
 
  Dim pArray As IArray
  Set pArray = New esriSystem.Array
  pArray.Add pDETableA
 
  Dim pFieldMapping As IGPFieldMapping
  Set pFieldMapping = New GPFieldMapping
  '** initialize the field mapping
  pFieldMapping.Initialize pArray, Nothing
 
  '** create a new output field
  Dim TrackIDField As IFieldEdit
  Set TrackIDField = New Field
  TrackIDField.Name = "TRACTID"
  TrackIDField.Type = esriFieldType.esriFieldTypeString
  TrackIDField.Length = 20

  '** create a new FieldMap
  Dim TrackID As IGPFieldMap
  Set TrackID = New GPFieldMap
  Set TrackID.OutputField = TrackIDField
  
  '** find field map STFID containing the input field STFID
  Dim FieldMap_Index As Long, Field_Index As Long
  FieldMap_Index = pFieldMapping.FindFieldMap("STFID")
 
  Dim STFID_FieldMap As IGPFieldMap
  Set STFID_FieldMap = pFieldMapping.GetFieldMap(FieldMap_Index)
 
  Field_Index = STFID_FieldMap.FindInputField(pDETableA, "STFID")
 
  Dim inputField As IField
  Set inputField = STFID_FieldMap.GetField(Field_Index)
 
  TrackID.AddInputField pDETableA, inputField, 5, 10  'starPos, endPos
  '** add the new field map to the field mapping
  pFieldMapping.AddFieldMap TrackID
 
  '** execute Table to Table tool using the FieldMapping
  Dim pParameters As IVariantArray
  Set pParameters = New varArray
  pParameters.Add (strTableA)
  pParameters.Add ("C:"Temp"VBTests"FieldMapping"citiblocks.gdb")
  pParameters.Add "census3"
  pParameters.Add ""
  pParameters.Add pFieldMapping
  GP.Execute "TableToTable_conversion", pParameters, Nothing
  Debug.Print GP.GetMessages(0)
  Exit Sub

EH:
  Debug.Print GP.GetMessages(2)

End Sub

 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值