[[GIS/RS knowledge base]]
#contents
*Arcpyはじめのいっぽ [#o9e760e6]
こんなときにはArcpyを使って処理するとべんりです。
--バッチ処理をしたいとき
--GUIで処理しようとしたら意味不明なエラーが出てきたとき
--マシンのスペックが低くてGUIを起動するだけで精いっぱいなとき~
結構簡単なのでお試しください。
--python用のエディタを用意するとよいです(Pythonインストール時に付いてくるIDLEでもよいです)~
テキストエディタでもよいですがpython用のエディタはインデント(pythonでは重要です)や関数などをわかりやすく整理・表示することができます。~
**シンプルな処理をしてみる [#h35c4c01]
&color(red){'''# arcpyをインポートする'''};~
import arcpy~
&color(red){'''# 必要なエクステンションがあるかどうかをチェックする'''};~
&color(red){'''# spatial analyst = "spatial"'''};~
&color(red){'''# 3D analyst = "3D"'''};~
arcpy.CheckOutExtension("spatial")~
&color(red){'''# 入出力する変数を定義する'''};~
&color(red){'''# パスとファイル名はダブルコーテーションで囲う'''};~
&color(red){'''# パス区切りは\\で行う'''};~
hexagons_shp = "D:\\test\\hexagons.shp"~
dem50gsi_j2ku54_img = "D:\\test\\dem50gsi_j2ku54.img"~
output_table = "D:\\temp\\zst_slope_02.dbf"~
&color(red){'''# 処理コマンド中に上記変数を入力する'''};~
&color(red){'''# 上記の変数以外の設定値はダブルコーテーションで囲って指定する'''};~
&color(red){'''# どのような変数が必須かはHELPを参照する'''};~
arcpy.gp.ZonalStatisticsAsTable_sa(hexagons_shp, "Unique_ID", dem50gsi_j2ku54_img, output_table, "NODATA", "ALL")~
&color(red){'''# 処理が終了したらfinishという文字を表示させる'''};~
print "finish"~

**たくさんのファイルをあつめてマージしてみる [#nffd14a7]
-ワイルドカード(*)を用いて複数ファイルを指定して実行する手順~

&color(red){'''# globモジュールをインポートする'''};~
import glob~
&color(red){'''# arcpyをインポートする'''};~
import arcpy~
&color(red){'''# 出力ファイルのパスと名前を指定'''};~
outputdata = "C:\\temp\\ps_merge_all.shp"~
&color(red){'''# ワイルドカードを使用して入力データリストを指定'''};~
files = glob.glob('C:\\temp\\*.shp')~
&color(red){'''# Process: マージ (Merge)'''};~
arcpy.Merge_management(files, outputdata)~
&color(red){'''# 処理終了時にfinishと出力する'''};~
print = "finish"~


**バッチ処理をしてみる [#yc5cd52d]
-for文を使って複数ファイルに同じ処理を実施する~
&color(red){'''# arcpyをインポートする'''};~
import arcpy~
&color(red){'''# 入力および出力ファイルのディレクトリを指定'''};~
input_dir = "D:\\last_p"~
output_dir = "D:\\last_p_out"~
&color(red){'''# ワイルドカードを使用して入力データリストを指定'''};~
try:~
    for x in [111, 222]:~
        &color(red){'''#変数の宣言'''};~
        fc = input_dir + "\\13lf" + str(x) + "_l_org_h.txt"~
        fc2 = str(x) + "_la"~
        fc3 = output_dir + "\\13lf" + str(x) + "_p_j2kxy13.shp"~
        &color(red){'''# Process: XY イベント レイヤの作成(Make XY Event Layer)'''};~
        arcpy.MakeXYEventLayer_management(fc, "x", "y", fc2, "", "z")~
        &color(red){'''# Process: フィーチャのコピー(Copy Features)'''};~
        arcpy.CopyFeatures_management(fc2, fc3, "", "0", "0", "0")~
        &color(red){'''# 処理が1サイクル正常に終了したら出力ファイル名を表示させる'''};~
        print str(x) + "_p_j2kxy13.shp"~
&color(red){'''# どこかで処理が停止した場合 "error" と表示させる'''};~
except:~
    print "error"~     
&color(red){'''# すべての処理が正常に終了したら"finish"と表示させる'''};~
print "finish"~

トップ   新規 一覧 単語検索 最終更新   ヘルプ   最終更新のRSS