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

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

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

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

メモリ ワークスペース

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

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

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

in_memory ワークスペース

レガシー:

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

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

注意:

ジオプロセシング ツールでは、in_memory 出力をマップに追加できません。 in_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")

制限事項

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

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