ジオプロセシング出力をメモリに書き込み

ジオプロセシング出力をメモリに書き込む処理は、出力をジオデータベースまたはファイルベースの形式に書き込む処理の代替手段となります。 ほとんどの場合、この処理は、ディスク上の形式に書き込む処理よりも、はるかに迅速に行われます。 メモリに書き込まれたデータは一時的なものであり、アプリケーションを閉じると削除されます。 メモリ ワークスペースは、ModelBuilder のモデルまたは Python スクリプトの中間データの書き込みに最適な場所です。

メモリベースのワークスペース

ArcGIS には、ジオプロセシング出力の書き込みができる 2 種類のメモリベースのワークスペースが用意されています。

メモリ ワークスペース

memory ワークスペースは、メモリベースのワークスペースであり、出力フィーチャクラス、テーブル、およびラスター データセットに対応しています。

次の方法で、memory ワークスペースに書き込みます。

  • ツール出力パラメーターの横にある [メモリ ワークスペース] ボタン メモリ ワークスペース を選択して、メモリ ワークスペース パスを作成します。
  • memory\ で始まる出力データセット パスを指定します。

出力名にファイル拡張子を含めないでください。 たとえば、出力を memory\tempOutput と指定します。

memory データセットを ArcGIS AllSource 内のマップに追加することができます。

in_memory ワークスペース

レガシー:

in_memory ワークスペースは、ArcMap 向けに構築された旧式のメモリベースのワークスペースであり、出力フィーチャクラス、テーブル、およびラスター データセットに対応しています。

in_memory ワークスペースに書き込むには、in_memory\ で始まりファイル拡張子がない出力データセット パスを指定します (例: in_memory\tempOutput)。

ジオプロセシング ツールでは、in_memory 出力を直接マップに追加することはできません。 in_memory 出力を作成すると、ツールでプロジェクト ジオデータベースにコピーが作成されます。 次に、この出力はプロジェクト ジオデータベースからマップに追加されます。 メモリベースのデータをマップ上に直接表示する場合は、代わりに memory ワークスペースを使用します。

次の条件の場合、ジオプロセシング ツールは、in_memory 出力をプロジェクト ジオデータベースにコピーしません。

memory ワークスペースとは異なり、in_memory ワークスペースはサブタイプやドメインをサポートしていません。

メモリ ワークスペースの管理

memory ワークスペースのデータは、ジオプロセシング ツールでのみ管理でき、[カタログ] ウィンドウやカタログ ビューには表示されません。 マップのどのレイヤーにメモリ データ ソースがあるかを調べるには、[コンテンツ] ペインで [データ ソース別にリスト] ボタン データ ソース別にリスト をクリックします。メモリ データ ソースは InMemoryDB\GPProMemoryWorkspace ワークスペースの下に一覧表示されます。

memory スペース内のデータセットのリストは、ArcPy リスト関数でも取得できます。

# Set the workspace and list the data saved to memory
arcpy.env.workspace = "memory"

print(f"Memory Feature Classes: {arcpy.ListFeatureClasses()}")
print(f"Memory Rasters: {arcpy.ListRasters()}")
print(f"Memory Tables: {arcpy.ListTables()}")

メモリベースのワークスペースを使用する場合は、すべての中間データをできるだけ早く削除して、システム メモリ リソースを解放します。 [削除 (Delete)] ツールを使用すると、メモリベースのワークスペース内にあるデータを削除できます。 データセットを個別に削除することも、ワークスペース全体を削除してワークスペースの内容を消去することもできます。

Python でのメモリ ワークスペースの使用

Python でのメモリベースのワークスペースの使用は、ジオプロセシング ツールにのみ有効です。 メモリは、ファイルやその他のデータを書き込める汎用の仮想ディレクトリではありません。

次のサンプル コードで示すように memory ワークスペースを使用します。

import arcpy

# Set the geoprocessing workspace
arcpy.env.workspace = r"C:\Data\Habitat.gdb"

# Buffer a Roads layer, writing output to memory 
arcpy.analysis.Buffer("Roads", r"memory\Buffers", 1000)

# Erase the buffers from a Vegetation layer
arcpy.analysis.Erase("Vegetation", r"memory\Buffers", r"memory\Erased")

# Dissolve the memory output of Erase to make a final output in the gdb workspace
arcpy.management.Dissolve(r"memory\Erased", "FinalOutput")

# Delete any intermediate datasets from memory
arcpy.management.Delete(r"memory\Erased")
arcpy.management.Delete(r"memory\Buffers")

制限事項

メモリベースのワークスペースには次の制限があります。

  • メモリベースのワークスペースは、フィーチャ データセット、リレーションシップ クラス、属性ルール、条件値、フィールド グループ、空間インデックスと属性インデックス、リプレゼンテーション、トポロジ、ジオメトリック ネットワーク、ネットワーク データセットなどのジオデータベース エレメントをサポートしていません。
  • [コピー (Copy)] ツールでは、メモリベースのワークスペース内のデータセットを入力または出力として使用できません。 メモリ ワークスペース内のデータセットをコピーするには、[フィーチャのコピー (Copy Features)] または [フィーチャのエクスポート (Export Features)] ツールを使用します。
  • [テーブルの切詰め (Truncate Table)] ツールでは、メモリベースのワークスペース内のデータを入力として使用できません。
  • メモリベースのワークスペースは、システムの物理メモリ (RAM) に格納されるため、このワークスペースに大規模なデータセットを書き込むと、システム メモリが不足する可能性があります。 これにより、処理のパフォーマンスに悪影響が及ぶことがあります。
  • フォルダーをメモリベースのワークスペース内に作成することはできません。
  • メモリ ワークスペースでは、[フィールドの変更 (Alter Field)] などのツールを使用した属性フィールドやスキーマの変更のサポートが限られています。 フィールド エイリアスは変更できますが、フィールド名などのプロパティは変更できません。