固定長ファイル書き込み処理

オペレーション名

固定長ファイル書き込み

機能概要

入力データを用いて固定長形式のテキストファイルを生成します。

データモデル

本コンポーネントのデータモデルはテーブルモデル型です。

プロパティ

変数の使用については、「変数」を参照してください。
基本設定
項目名 必須/省略可 変数の使用 説明 備考
名前 必須 使用不可 スクリプトキャンバス上での名前を入力します。  
入力データ 必須 使用不可 スクリプトキャンバス上にあるコンポーネントを選択します。  
必須設定
項目名 必須/省略可 変数の使用 説明 備考
ファイル 必須 使用可 書き込みを行う固定長ファイルパスを入力します。

[参照]ボタンを押下するとファイルチューザが起動し、ファイルの選択ができます。
フォーマット 必須 使用不可 グローバルリソースに登録されている固定長ファイルフォーマット定義を選択します。
設定方法については、「固定長書き込みウィザード」を参照してください。
  • [追加]:
    新規にグローバルリソースを追加します。
  • [編集]:
    「リソース一覧の編集」画面にて、グローバルリソースの設定を編集することができます。
 
プロパティアクション
項目名 説明 備考
プレビュー プレビューアを起動して、[ファイル]で指定したファイルの内容を表示します。
  • 指定したファイルが存在しない場合、または[ファイル]に変数が設定されている場合は無効になります。
  • [エンコード]で指定したエンコードで表示されます。
  • ファイル内容の編集はできません。
  • プレビューアで表示できるファイルのサイズは最大1MBです。ファイルサイズが1MBを超える場合、ファイルの先頭から1MB分が表示されます。
書き込み設定
項目名 必須/省略可 変数の使用 説明 備考
エンコード 必須 使用可 書き込むファイルのエンコードを選択または入力します。

入力する場合は、Java SE Runtime Environment 8でサポートされているエンコードを指定します。
詳細については、「Supported Encodings」(http://docs.oracle.com/javase/8/docs/technotes/guides/intl/encoding.doc.html)を参照してください。
改行コード 必須 使用不可 改行コードを選択します。
  • [AUTO]:(デフォルト)
    処理系依存
  • [NONE]:
  • [CR]:
    主にMac OS(バージョン9まで)
  • [LF]:
    主にUNIX/Linux
  • [CR+LF]:
    主にMicrosoft Windows
  • 改行コードは[エンコード]で指定したエンコードでエンコーディングされるため、バイト値はエンコードによって異なります。
    • LF
      エンコード バイト値
      UTF-8 0x0a
      Shift_JIS 0x0a
      Windows-31J 0x0a
      EUC-JP 0x0a
      ISO-8859-1 0x0a
      ISO-2022-JP 0x0a
      US-ASCII 0x0a
      UTF-16 0xfe,0xff,0x00,0x0a
      UTF-16BE 0x00,0x0a
      UTF-16LE 0x0a,0x00
      Cp930 (EBCDIC) 0x15

    • CR
      エンコード バイト値
      UTF-8 0x0d
      Shift_JIS 0x0d
      Windows-31J 0x0d
      EUC-JP 0x0d
      ISO-8859-1 0x0d
      ISO-2022-JP 0x0d
      US-ASCII 0x0d
      UTF-16 0xfe,0xff,0x00,0x0d
      UTF-16BE 0x00,0x0d
      UTF-16LE 0x0d,0x00
      Cp930 (EBCDIC) 0x0d

    • CRLF
      エンコード バイト値
      UTF-8 0x0d,0x0a
      Shift_JIS 0x0d,0x0a
      Windows-31J 0x0d,0x0a
      EUC-JP 0x0d,0x0a
      ISO-8859-1 0x0d,0x0a
      ISO-2022-JP 0x0d,0x0a
      US-ASCII 0x0d,0x0a
      UTF-16 0xfe,0xff,0x00,0x0d,0x00,0x0a
      UTF-16BE 0x00,0x0d,0x00,0x0a
      UTF-16LE 0x0d,0x00,0x0a,0x00
      Cp930 (EBCDIC) 0x0d,0x15
上書き 省略可 使用不可 指定したファイルが存在する場合、上書きするかどうかを選択します。
  • [チェックあり]:(デフォルト)
    上書きします。
  • [チェックなし]:
    上書きしません。すでにファイルが存在した場合はエラーとなります。
 
追加書き込み 省略可 使用不可 指定したファイルが存在する場合、ファイルの末尾に追加するまたは上書きするかを選択します。
  • [チェックあり]:
    ファイルの末尾に追加します。
  • [チェックなし]:(デフォルト)
    上書きします。
  • [上書き]にチェックを入れた場合のみ有効になります。
トランザクション
項目名 必須/省略可 変数の使用 説明 備考
トランザクション処理を行う 必須 使用不可 トランザクション処理を行うかどうかを選択します。
  • [チェックあり]:
    トランザクション処理を行います。
  • [チェックなし]:(デフォルト)
    トランザクション処理を行いません。
詳細については、「ファイル系アダプタのトランザクション」を参照してください。
 
コメント
項目名 必須/省略可 変数の使用 説明 備考
コメント 省略可 使用不可 このアダプタの簡単な説明を記述することができます。
説明を記述すると、仕様書に反映させることができます。
 

スキーマ

入力スキーマ

[フォーマット]の設定により、カラム数が異なります。
スキーマ構造については、「テーブルモデル型のスキーマ」を参照してください。

出力スキーマ

ありません。

Mapperでのスキーマ読み込み

スキーマは自動で読み込まれます。
詳細については、「スキーマ編集」を参照してください。

トランザクション

トランザクションをサポートしています。

[トランザクション][トランザクション処理を行う]にチェックを入れた場合のみトランザクションは有効になります。

PSPでの使用について

PSPで使用できます。
PSPについては、「パラレルストリーミング処理」を参照してください。

使用できるコンポーネント変数

コンポーネント変数名 説明 備考
count 書き込んだデータの件数が格納されます。
  • デフォルト値はnullです。
message_category エラー発生時、発生したエラーに対応するメッセージコードのカテゴリが格納されます。
  • デフォルト値はnullです。
message_code エラー発生時、発生したエラーに対応するメッセージコードのコードが格納されます。
  • デフォルト値はnullです。
message_level エラー発生時、発生したエラーに対応するメッセージコードの重要度が格納されます。
  • デフォルト値はnullです。
error_type エラー発生時、発生したエラーの種類が格納されます。
  • デフォルト値はnullです。
  • エラーの種類は、以下のような形式となります。
    例:「java.io.FileNotFoundException」
  • DataSpider Servistaのバージョンにより、格納される内容が変わる可能性があります。
error_message エラー発生時、発生したエラーのメッセージが格納されます。
  • デフォルト値はnullです。
  • DataSpider Servistaのバージョンにより、格納される内容が変わる可能性があります。
error_trace エラー発生時、発生したエラーのトレース情報が格納されます。
  • デフォルト値はnullです。
  • DataSpider Servistaのバージョンや実行するクライアントアプリケーションにより、格納される内容が変わる可能性があります。

仕様制限

主な例外

例外名 原因 対策
InputDataNotFoundException [入力データ]が指定されていません。 [入力データ]を指定する、またはデータフローを引いてください。
ResourceNotFoundException
リソース定義が見つかりませんでした。名前:[]
[フォーマット]が指定されていません。 [フォーマット]を指定してください。
ResourceNotFoundException
リソース定義が見つかりませんでした。名前:[<グローバルリソース名>]
[フォーマット]で選択されたリソース定義が見つかりません。 [フォーマット]で指定したグローバルリソースを確認してください。
InvalidPropertyConfigurationException
<プロパティ名>が指定されていません。
[<プロパティ名>]が指定されていません。 [<プロパティ名>]を指定してください。
FileIsDirectoryException [ファイル]に入力されたパスがディレクトリです。 [ファイル]にはファイルパスを入力してください。
FileAlreadyExistedException [ファイル]に指定されたファイルがすでに存在します。 [ファイル]のファイル名を変更する、または[書き込み設定][上書き]にチェックを入れてください。
FileIsLockedException [ファイル]に指定されたファイルがロックされています。 エクスプローラやCLIからロックの解除を行ってください。
ArrayIndexOutOfBoundsException [フォーマット]で指定した列一覧のフィールド数が、入力元XMLデータのカラム数より大きい可能性があります。 [フォーマット]で指定した列一覧のフィールド数または、入力元XMLデータのカラム数を確認してください。
java.io.FileNotFoundException
別のプロセスが使用中です。
[ファイル]に指定されたファイルが別のプロセスによって使用されています。 別のプロセスで使用されていないかを確認してください。
java.io.UnsupportedEncodingException [エンコード]にサポートされていないエンコードが指定されています。 Java SE Runtime Environment 8でサポートされているエンコードを指定してください。
詳細については、「Supported Encodings」(http://docs.oracle.com/javase/8/docs/technotes/guides/intl/encoding.doc.html)を参照してください。
IllegalPaddingException
パディング文字が入り切りませんでした
パディングを行った結果、フィールドのデータがフィールド長以上になっています。 パディング文字の設定や入力データを確認してください。
java.lang.ArithmeticException
/ by zero
パディング文字が未入力であるため、パディングに失敗しました。 パディング文字の設定や入力データを確認してください。

注意事項