> For the complete documentation index, see [llms.txt](https://primer2.dynamobim.org/llms.txt). Markdown versions of documentation pages are available by appending `.md` to page URLs; this page is available as [Markdown](https://primer2.dynamobim.org/ja/dynamo-for-civil-3d/sample-workflows/utilities/rename-structures.md).

# 構造物の名前を変更する

<figure><img src="/files/iSnklEEoxhR5pGlbao7k" alt=""><figcaption></figcaption></figure>

パイプ ネットワークにパイプと構造物を追加する場合、Civil 3D はテンプレートを使用して名前を自動的に割り当てます。通常、初期の配置時にはこの値で十分ですが、設計が進行するにつれて、必然的に名前を変更する必要が出てきます。さらに、要求される命名パターンは多数あります。たとえば、パイプ配管内で最も下流の構造物から始めて構造物に順番に命名したり、現地の関係機関のデータ スキーマに沿った命名パターンに従ったりすることです。この例では、Dynamo を使用して、あらゆるタイプの命名方法を定義して、一貫して適用する方法を示します。

## 目標

> :dart: Alignment の測点に基づいて、パイプ ネットワーク構造物の名前を順番に変更します。

## 主要な概念

> * バウンディング ボックスを操作する
> * **List.FilterByBoolMask** ノードを使用してデータをフィルタする
> * **List.SortByKey** ノードを使用してデータを並べ替える
> * テキスト文字列を生成および修正する

## バージョンの互換性

{% hint style="success" %}
このグラフは \*\*Civil 3D 2020\*\* 以降で実行できます。
{% endhint %}

## データセット

まず、以下のサンプル ファイルをダウンロードし、DWG ファイルと Dynamo グラフを開きます。

{% file src="/files/RSgjrGlBUwtoJMczKcZf" %}

{% file src="/files/kmupd9vXnhAxSTmauSSP" %}

## 対処法

このグラフのロジックの概要を以下に示します。

> 1. レイヤ別に構造物を選択する
> 2. 構造物の位置を取得する
> 3. 構造物をオフセットでフィルタし、測点で並べ替える
> 4. 新しい名前を生成する
> 5. 構造物の名前を変更する

以上です。

### 構造物を選択する

最初に、作業する構造物をすべて選択する必要があります。これを行うには、単純に特定のレイヤ上のすべてのオブジェクトを選択します。つまり、異なるパイプ ネットワークから構造物を選択できます(同じレイヤを共有していると仮定します)。

<figure><img src="/files/NrC8mz6VlbY2TTZ15Qhp" alt=""><figcaption><p>特定のレイヤ上の構造物を選択する</p></figcaption></figure>

> 1. このノードを使用すると、構造物と同じレイヤを共有する可能性のある不要なオブジェクト タイプを誤って取り出すことがなくなります。

### 構造物の位置を取得する

構造物が取得できたので、空間内での構造物の位置を特定し、位置に応じて構造物を並べ替えられるようにする必要があります。これを行うには、各オブジェクトのバウンディング ボックスを利用します。オブジェクトの**バウンディング ボックス**は、オブジェクトのジオメトリ範囲を完全に含む最小サイズのボックスです。バウンディング ボックスの中心を計算することで、構造物の挿入位置に非常に近い値が得られます。

<figure><img src="/files/gcCpMbCOaTbegO20wHhh" alt=""><figcaption><p>バウンディング ボックスを使用して各構造物のおおよその挿入位置を取得する</p></figcaption></figure>

これらの挿入位置を使用し、選択した Alignment を基準にして構造物の測点とオフセットを取得します。

<div><figure><img src="/files/cRNM8miX52a8j0iDr9o8" alt="" width="268"><figcaption></figcaption></figure> <figure><img src="/files/pbQmSghrk1og4pK8YiBp" alt="" width="306"><figcaption></figcaption></figure></div>

### フィルタと並べ替え

ここでは、少し面倒な作業を開始します。この段階では、指定したレイヤ上のすべての構造物の大きなリストを取得し、それを並べ替える Alignment を選択しました。問題は、名前を変更したくない構造物がリストに含まれている可能性があることです。たとえば、構造物が対象となる特定の経路に含まれていない場合があります。

<figure><img src="/files/7CkBsNQsOaTCmvC5kFrd" alt="" width="555"><figcaption></figcaption></figure>

> 1. 選択された Alignment
> 2. 名前を変更する構造物
> 3. 無視する必要がある構造物

そのため、Alignment からの特定のオフセットよりも外にある構造物は対象に含めないように、構造物のリストをフィルタする必要があります。これは、**List.FilterByBoolMask** ノードを使用して行うのが最適です。構造物のリストをフィルタした後、**List.SortByKey** ノードを使用して、測点値で並べ替えます。

{% hint style="info" %}
リストを初めて使用する場合は、「 [リストの操作](/ja/5_essential_nodes_and_concepts/5-4_designing-with-lists/2-working-with-lists.md) 」セクションを参照してください。
{% endhint %}

<figure><img src="/files/RAnrDzb9369nzJvSHcQ1" alt=""><figcaption><p>構造物をフィルタし、並べ替える</p></figcaption></figure>

> 1. 構造物のオフセットがしきい値より小さいかどうかを確認する
> 2. Null 値を *false* に置き換える
> 3. 構造物と測点のリストをフィルタする
> 4. 構造物を測点で並べ替える

### 新しい名前を生成する

最後に、構造物の新しい名前を作成する必要があります。使用する形式は `<alignment name>-STRC-<number>` です。ここに、必要に応じてゼロを追加して数値に埋め込むための追加ノードがいくつかあります(例: 「1」を「01」に)。

<figure><img src="/files/SoFpFvW0CvUxNEagNINS" alt=""><figcaption><p>新しい構造物の名前を生成する</p></figcaption></figure>

### 構造物の名前を変更する

最後に、構造物の名前を変更します。

<figure><img src="/files/CYV9xDBX12qFmn7ujdpn" alt="" width="289"><figcaption><p>構造物の名前を設定する</p></figcaption></figure>

### 結果

以下に、**Dynamo プレーヤ**を使用してグラフを実行する例を示します。

<figure><img src="/files/iSnklEEoxhR5pGlbao7k" alt=""><figcaption><p>Dynamo プレーヤを使用してグラフを実行し、Civil 3D で結果を確認する</p></figcaption></figure>

{% hint style="info" %}
Dynamo プレーヤを初めて使用する場合は、「 [Dynamo プレーヤ](/ja/dynamo-for-civil-3d/dynamo-player.md) 」セクションを参照してください。
{% endhint %}

> :tada: ミッションが達成されました。

### ボーナス: Dynamo での視覚化

Dynamo の 3D バックグラウンド プレビューを利用して、最終的な結果だけでなく、グラフの中間出力を視覚化すると便利です。簡単に行える方法の 1 つは、構造物のバウンディング ボックスを表示することです。さらに、この特定のデータセットにはドキュメントにコリドーがあるため、コリドー計画線ジオメトリを Dynamo に取り込んで、構造物が空間内のどこに位置するかを確認することができます。グラフがコリドーを持たないデータセットで使用されている場合、これらのノードは何も実行しません。

<figure><img src="/files/mTsbcRIP7hU97nhfXdSP" alt=""><figcaption><p>構造物とコリドー計画線のジオメトリを視覚化する</p></figcaption></figure>

これで、オフセットによる構造物のフィルタ処理がどのように機能するかを理解できるようになりました。

<figure><img src="/files/vbD4Ghkdp8zkEYE5WndK" alt=""><figcaption><p>Alignment オフセットのしきい値を調整し、影響を受ける構造物を Dynamo で視覚化する</p></figcaption></figure>

## アイデア

このグラフの機能を拡張する方法について、いくつかのアイデアを示します。

{% hint style="info" %}
特定の Alignment を選択するのではなく、**最も近い Alignment** に基づいて構造物の名前を変更します。
{% endhint %}

{% hint style="info" %}
構造物に加えて **パイプの名前も変更します**。
{% endhint %}

{% hint style="info" %}
経路に基づいて構造物の **レイヤを設定します**。
{% endhint %}


---

# Agent Instructions
This documentation is published with GitBook. GitBook is the documentation platform designed so that both humans and AI agents can read, navigate, and reason over technical content effectively. Learn more at gitbook.com.

## Querying This Documentation
If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter, and the optional `goal` query parameter:

```
GET https://primer2.dynamobim.org/ja/dynamo-for-civil-3d/sample-workflows/utilities/rename-structures.md?ask=<question>&goal=<endgoal>
```

`ask` is the immediate question: it should be specific, self-contained, and written in natural language.
`goal` is optional and describes the broader end goal you are ultimately trying to accomplish on behalf of the user. GitBook uses it to tailor the answer towards what is most useful for that goal.

The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
