YouTube | Facebook | X(Twitter) | RSS

フィールド演算の実行

2016/9/1 (木)

Public Sub FieldCalculator()
    Dim pMxDocument As IMxDocument
    Set pMxDocument = ThisDocument
     
    Dim pFeatureLayer As IFeatureLayer
    Set pFeatureLayer = pMxDocument.FocusMap.Layer(0)
     
    Dim pTable As ITable
    Set pTable = pFeatureLayer.FeatureClass
     
    'フィールド演算
    Dim pCursor As ICursor
    Set pCursor = pTable.Update(Nothing, False) 'UpdateCursor が必要
     
    Dim pCalculator As ICalculator
    Set pCalculator = New Calculator
    Set pCalculator.Cursor = pCursor
    pCalculator.PreExpression = "Dim dblLength" & vbNewLine & _
                                "dblLength = [JCODE]"    'コード ブロック(バージョン10はVBScriptのみ使用可能)
    pCalculator.Expression = "dblLength"
    pCalculator.Field = "P_NUM"                     'フィールド名
  
    pCalculator.Calculate
 
End Sub
#フィールド演算でPythonを使用
 
#コードブロックを表示
def theFunction(theGeometry):
    return 'ジオメトリ タイプ : ' + theGeometry.type
 
----------
theFunction(!Shape!)
 
※日本語の文字列連結でエラー
ex) "ジオメトリ タイプ : " + theGeometry.type
 
※日本語文字の比較演算ができない(結果がfalseとなる)
ex) if aaa == "北海道"]:

関連記事

  • この記事を書いた人

羽田 康祐

伊達と酔狂のGISエンジニア。GIS上級技術者、Esri認定インストラクター、CompTIA CTT+ Classroom Trainer、潜水士、PADIダイブマスター、四アマ。WordPress は 2.1 からのユーザーで歴だけは長い。 代表著書『地図リテラシー入門―地図の正しい読み方・描き方がわかる』 GIS を使った自己紹介はこちら。ESRIジャパン(株)所属、元青山学院大学非常勤講師を兼務。日本地図学会第31期常任委員。発言は個人の見解です。

-プログラミング
-,

WINGFIELD since1981をもっと見る

今すぐ購読し、続きを読んで、すべてのアーカイブにアクセスしましょう。

続きを読む