使用頻度の高いロジックの組み合わせを関数化したい

キーワード:ユーザ定義ロジック,ローカルユーザ定義ロジック,文字連結,半角全角変換,関数,ファンクション
シナリオ一覧に戻る

概要

使用頻度の高いロジックの組み合わせを関数化したい場合、ユーザ定義ロジックを作成します。
ユーザ定義ロジックは、Mapperロジックを組み合わせて1つのロジックとしてまとめることが可能です。
作成したユーザ定義ロジックは、同一プロジェクト内のドキュメントMapperおよび変数Mapper上で共有できます。

サンプルプロジェクトの説明

ローカルユーザ定義ロジックを作成して以下の処理を行い、処理結果をスクリプト変数に代入します。

処理の流れ

サンプルプロジェクトの処理の流れは以下の通りです。
  1. 変数代入処理」の「ユーザ定義ロジック」で以下の処理を行い、処理結果をスクリプト変数「結合された住所」に代入します。
    1. 4つのスクリプト変数(「都道府県名」・「市区町村名」・「住所1」・「住所2」)の値を結合します。
    2. スクリプト変数「住所1」および「住所2」に含まれる半角の文字・数字・記号を全角に変換します。
スクリプトを実行すると、スクリプト変数「結合された住所」に処理結果が代入されます。

ポイントとなる機能

名前 説明 ツールパレット上の場所
ローカルユーザ定義ロジック 複数のMapperロジックを1つのロジックとしてまとめ、同一プロジェクト内のドキュメントMapperおよび変数Mapper上で共有できる機能です。 「ローカルユーザ定義」

処理のポイント

作成したローカルユーザ定義ロジックは、同一プロジェクト内のドキュメントMapperおよび変数Mapper上で共有できます。
ローカルユーザ定義ロジックを変更すると、配置したローカルユーザ定義ロジックすべてに変更が反映されます。
そのため、同一の処理を何度も行う場合など、共通の処理をローカルユーザ定義ロジック化すると効果的です。
なお、ローカルユーザ定義ロジックは別のプロジェクトにコピーすることができません。
複数のプロジェクトで同一のローカルユーザ定義ロジックを使用したい場合、テンプレートとして使用するプロジェクトおよびローカルユーザ定義ロジックを作成しておき、そのプロジェクトをコピーして使用する方法があります。
ただし、コピー元のローカルユーザ定義ロジックを変更してもコピー先のローカルユーザ定義ロジックに変更が反映されないため、必要に応じて各プロジェクト内のローカルユーザ定義ロジックを変更する必要があります。
ローカルユーザ定義ロジックの詳細については、「ユーザ定義ロジック」を参照してください。

サンプルプロジェクトの使用方法

上記処理を実装したサンプルプロジェクトを用意しています。サンプルプロジェクトを使用する場合の手順は、以下の通りです。

サンプルプロジェクトファイル名 rl_reference_040.zip
  1. サンプルプロジェクトの展開
    サンプルプロジェクトファイル「rl_reference_040.zip」を展開します。

  2. プロジェクトのアップロード
    「rl_reference_040.zip」を展開後に作成される「rl_reference_040プロジェクト」ディレクトリがプロジェクトファイルとなります。
    DataSpider Studioを起動し、マイプロジェクトの画面から[ファイル]-[ローカルからアップロード]で展開したディレクトリ「rl_reference_040プロジェクト」をアップロードしてください。

スクリプトの作成手順

プロセスフローは、「サンプルプロジェクトの説明」のスクリプト画像を参照して適宜設定してください。
  1. 入力データ・出力データとして使用するスクリプト変数を作成します。

  2. デザイナのツールパレット「基本」-「処理」-「変数代入」から、変数代入処理をスクリプトキャンバスに配置します。

  3. 変数代入処理のMapperエディタを開き、ツールパレットの「ローカルユーザ定義」パレットの右クリックメニューから[追加]-[ユーザ定義ロジック]を選択します。

  4. 「ユーザ定義ロジックの追加」画面で、[ユーザ定義ロジック名]に「ユーザ定義ロジック」を入力し、[OK]を押下します。

  5. 新しいローカルユーザ定義ロジックが作成され、ツールパレット上に表示されます。

  6. ツールパレットの「ローカルユーザ定義」パレットにある「ユーザ定義ロジック」をダブルクリックしてMapperエディタを開きます。
    「都道府県名」・「市区町村名」・「住所1」・「住所2」の値を結合し、「住所1」および「住所2」に含まれる半角の文字・数字・記号を全角に変換する処理を作成します。

  7. 変数代入のMapperエディタに戻り、作成したユーザ定義ロジックを使用して変換した値を、スクリプト変数「結合された住所」に代入する処理を作成します。

  8. スクリプトを実行し、正常終了すれば成功です。