Tukubaiオンラインコマンドマニュアル - join2x(1)
join2x(1)
【名前】
join2x
: キーの値が同じレコードが複数存在するファイル同士を連結。
【書式】
Usage : join2x [-d<string> | +<string>] key=<key> <master> [<tran>] Version : Fri Jul 22 01:09:14 JST 2022
【説明】
テキストファイル<tran>
の"key=<n>"
で指定したキーフィールドがマスターファイル<master>
の第1フィールド(キーフィールド)とマッチした行を<tran>
から抽出して、<master>
の情報を連結して出力します。マッチしない行は、ダミーデータ"_"
をフィールド数分だけ結合して出力します。ダミーデータは指定することもできます。
複数のキーフィールドがある場合、<master>
のキーフィールドは、<tran>
のキーフィールドと同じ並びで、最小フィールドが1となるようスライドさせたキーフィールドとなります。例えば、key=3/5
のときは、並び=3フィールド連続したキー、なので、<master>
は1から3連続したフィールド、つまり、第1から第3フィールドがキーとなります。
masterまたはtranに-
を指定すると標準入力を使用する。tranが無指定の場合には標準入力を使用する。
<master>
の第1フィールドおよび<tran>
のキーフィールドについては必ず昇順でソートされていることが条件になります。
<master>
が空ファイル(0バイト)の場合はエラーになります。
join2
との違いは、マスターファイルのキーフィールドの値が同一のレコードが複数存在できる点です。マスターとトランザクションファイルのキーフィールド値が同一のレコード同士を総掛けで連結して出力します。
【例1】
(マスターファイル:master)
$ cat master 1 東京1 1 東京2 2 大阪1 2 大阪2
(トランザクションファイル:tran)
$ cat tran 1 新宿 1 上野 2 梅田 2 難波 2 京橋 3 金山 3 栄 3 熱田 4 博多 4 天神
$ join2x key=1 master tran >data $ cat data 1 東京1 新宿 1 東京2 新宿 1 東京1 上野 1 東京2 上野 2 大阪1 梅田 2 大阪2 梅田 2 大阪1 難波 2 大阪2 難波 2 大阪1 京橋 2 大阪2 京橋 3 _ 金山 3 _ 栄 3 _ 熱田 4 _ 博多 4 _ 天神