public class Process_GrepChange extends AbstractProcess implements ChainProcess
Process_GrepChange は、上流から受け取った FileLineModelから、語句を
置換する、ChainProcess インターフェースの実装クラスです。
Process_Grep との違いは、チェックするファイルのコピーを(キーワードが存在
しなくとも)作成することと、検索キーに正規表現が使えない、複数行置き換えが
出来ないことです。
keywordFile より、置換する語句を含むキーと値のペアー(タブ区切り)を読取り、
対象とする語句を置換します。
keywordFile に、タブが含まれない行や、先頭にタブが存在している場合は、
その行を読み飛ばします。また、区切りタブは何個存在しても構いません。
置換文字(値)は、\t の特殊文字が使用できます。
この GrepChange では、語句に、正規表現は使用できません。正規表現のキーワード
や文字列を複数行の文字列と置き換える場合は、Process_Grep を使用してください。
このプログラムでは、上流から受け取った FileLineModel のファイルに対して、
置き換えた結果も、同じファイルにセーブします。
元のファイルを保存したい場合は、予めバックアップを取得しておいてください。
-inEncode は、入力ファイルのエンコード指定になります。
-outEncode は、出力ファイルのエンコードや、キーワードファイルの
エンコード指定になります。(keywordFile は、必ず 出力ファイルと同じエンコードです。)
これらのエンコードが無指定の場合は、System.getProperty("file.encoding") で
求まる値を使用します。
5.7.3.2 (2014/02/28)
-regex=true で、キーワードに正規表現を利用できます。具体的には、String#replaceAll(String,String)
を利用して置換します。
通常の置換処理は、indexOf で見つけて、StringBuilder#replace(int,int,String) を繰り返して処理しています。
-ignoreCase=true で、検索キーワードに大文字小文字を区別しない処理が可能です。
上流プロセスでは、Name 属性として、『File』を持ち、値は、Fileオブジェクト
である、Process_FileSearch を使用するのが、便利です。それ以外のクラスを
使用する場合でも、Name属性と、File オブジェクトを持つ LineModel を受け渡し
できれば、使用可能です。
引数文字列中にスペースを含む場合は、ダブルコーテーション("") で括って下さい。
引数文字列の 『=』の前後には、スペースは挟めません。必ず、-key=value の様に
繋げてください。
Process_GrepChange -keyword=検索文字列 -ignoreCase=true -outfile=OUTFILE -encode=UTF-8
-keywordFile=キーワード :置換する語句を含むキーと値のペアー(タブ区切り)
[-ignoreCase=[false/true] ] :検索時に大文字小文字を区別しない(true)かどうか(初期値:false[区別する])
[-regex=[false/true] ] :キーワードに正規表現を利用する(true)かどうか(初期値:false[利用しない])
[-isChange=置換可否 ] :置換処理を実施する(true)かどうか(初期値:置換する[true])
[-inEncode=入力エンコード ] :入力ファイルのエンコードタイプ
[-outEncode=出力エンコード] :出力ファイルやキーワードファイルのエンコードタイプ
[-display=[false/true] ] :結果を標準出力に表示する(true)かしない(false)か(初期値:false[表示しない])
[-debug=[false/true] ] :デバッグ情報を標準出力に表示する(true)かしない(false)か(初期値:false[表示しない])BUFFER_LARGE, BUFFER_MIDDLE, CR, TAB| コンストラクタと説明 |
|---|
Process_GrepChange()
デフォルトコンストラクター。
|
| 修飾子とタイプ | メソッドと説明 |
|---|---|
LineModel |
action(LineModel data)
引数の LineModel を処理するメソッドです。
|
void |
end(boolean isOK)
プロセスの終了を行います。
|
void |
init(ParamProcess paramProcess)
プロセスの初期化を行います。
|
static void |
main(String[] args)
このクラスは、main メソッドから実行できません。
|
String |
report()
プロセスの処理結果のレポート表現を返します。
|
String |
usage()
このクラスの使用方法を返します。
|
getArgument, logging, println, putArgument, putArgument, setLoggerProcess, toStringclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitlogging, println, putArgument, putArgument, setLoggerProcesspublic Process_GrepChange()
public void init(ParamProcess paramProcess)
init インタフェース内 HybsProcessparamProcess - データベースの接続先情報などを持っているオブジェクト| 5.1.2.0 (2010/01/01) 置換するかどうかを指定可能にする(isChange)属性追加 |
| 5.7.3.2 (2014/02/28) debug の表示と、キーワードの \t の使用、trim() 廃止、ignoreCase の実装、regex の追加 |
public void end(boolean isOK)
end インタフェース内 HybsProcessisOK - トータルで、OKだったかどうか[true:成功/false:失敗]public LineModel action(LineModel data)
action インタフェース内 ChainProcessdata - オリジナルのLineModel| 4.0.0.0 (2007/11/28) メソッドの戻り値をチェックします。 |
| 5.1.2.0 (2010/01/01) 置換するかどうかを指定可能にする(isChange)属性追加 |
| 5.7.2.2 (2014/01/24) エラー時にデータも出力します。 |
| 5.7.3.2 (2014/02/28) debug の表示と、ignoreCase の実装 |
public String report()
report インタフェース内 HybsProcesspublic String usage()
usage インタフェース内 HybsProcesspublic static void main(String[] args)
args - コマンド引数配列Webアプリケーションフレームワーク openGionCopyright (c) 2009 The openGion Project.