はじめに
またもやRecordGroupです。PDFとの相性が良いのでは?という事で2312にて新しくなったPDFコンポーネントで、伝票の様なものを作るサンプルです。
一からフォーマット作るのは面倒なので、こちらのサイトの帳票を明細を5行に詰めて利用しています。
ビジネステンプレート 発注書エクセルテンプレート(無料)_タテ型_001
今回の処理で不要な箇所はそのまま固定値で出力しています。数字のカンマ、日付の変換のみ行います。CSVデータはchatGPTでEXCELの出力項目に従った内容で生成したものを利用しています。
RecordGroups使用 処理内容
下記CSVファイル(ヘッダ、明細)をPDFコンポーネントで発注番号ごとにPDF化します。
発注NO,発注日,取引先,件名,納期,納品場所,支払条件
12345,2024年02月10日,株式会社ABC商事,商品の納品に関する件,2024年02月20日,東京都中央区,30日ネット
23456,2024年02月11日,株式会社XYZ商店,納品依頼書,2024年02月25日,大阪市北区,45日払い
34567,2024年02月12日,株式会社123商事,納品のお願い,2024年02月18日,名古屋市中区,銀行振込
45678,2024年02月13日,株式会社456商店,商品のご注文,2024年02月28日,福岡市西区,60日ネット
56789,2024年02月14日,株式会社789商事,納品書のお知らせ,2024年02月22日,札幌市中央区,銀行振込
発注NO,明細NO,品名,数量,単位,単価,金額
12345,1,商品A,10,個,1000,10000
12345,2,商品B,5,個,2000,10000
12345,3,商品C,3,個,1500,4500
12345,4,商品D,2,個,1800,3600
12345,5,商品E,8,個,1200,9600
12345,6,商品F,4,個,700,2800
12345,7,商品G,6,個,3000,18000
12345,8,商品H,7,個,2500,17500
23456,1,商品I,15,個,900,13500
23456,2,商品J,10,個,1600,16000
23456,3,商品K,6,個,1800,10800
23456,4,商品L,4,個,500,2000
34567,1,商品M,12,個,800,9600
34567,2,商品N,5,個,1500,7500
34567,3,商品O,8,個,1700,13600
34567,4,商品P,10,個,1200,12000
45678,1,商品Q,7,個,2000,14000
45678,2,商品R,5,個,1300,6500
45678,3,商品S,9,個,1100,9900
45678,4,商品T,8,個,1800,14400
56789,1,商品U,6,個,700,4200
56789,2,商品V,9,個,1600,14400
56789,3,商品W,3,個,2000,6000
56789,4,商品X,5,個,900,4500
処理フロー
フロー変数
フロー変数 | データ型 | 初期値 |
---|---|---|
vWorkFolder | String | wk |
v発注NO | String |
【処理概要】
- ワークフォルダの削除
- header、meisaiのCSVファイルの読み込みをし発注NOでJOINする
- RecordGroupのループ(発注NO)
- 明細NOでソートを行い、PDFのレコードに合わせてマッピング、発注NOをフロー変数に格納
- PDF生成
- フロー変数に保存された発注NOを利用しファイルの出力
ワークフォルダを先頭で削除する方法は、筆者が好んで行う初期処理です。処理の作業情報が1世代だけフォルダに残るため異常時の初期調査のためにその様にしています。他にもMutexを先頭に入れますが今回は省略しています。
フロー自体はRecordGroupで発注NO毎のストリームに分解し、集計やPDFの改ページ等気にせずそのまま移送できるので非常に単純な構成となっています。
PDFコンポーネント
PDFコンポーネントでPDFビルダーを起動し単一セル、レコードを指定します。
ページ選択は、単票、複票ともに行います。
単票・単一セル

単票・レコード

複票(先頭)・単一セル

複票(先頭)・レコード

複票(中間)・単一セル

複票(中間)・レコード

複票(末尾)・単一セル

複票(末尾)・レコード

Mapper
Mapperではレイヤーを3つ指定していますが、明細と集計は同一レイヤーでも問題ありません。
普通のデータであれば、明細データに税区分や税額など入っていると思いますが、今回はマッパー内で10%で強制的に算出しています。
条件なしレイヤーで明細と集計を行い、レコードの最終行でヘッダ部や明細合計などにまとめて移送します。
マッパー変数
マッパー変数 | データ型 | 初期値 |
---|---|---|
小計 | Decimal | |
消費税 | Decimal |
レイヤー
レイヤー名 | レイヤー条件 |
---|---|
明細 | なし |
集計 | なし |
最終行 | $stream.RecordNo = $stream.RecordCount |
FilePut
FilePutではPDFのバイナリを
${flow.vWorkFolder}/発注書_${flow.get("v発注NO")}.pdf
に出力しています。
RecordGroups未使用 処理内容
RecordGroupを使用しない場合にどの様なフローとなるかを比較のために構築してみました。といってもPDFコンポーネントの特性を考えると、入力ストリームが1発注NO毎の明細とヘッダ部、集計という構成自体は変わりません。いかにその形のストリームをPDFコンポーネントに入れるか、という事が必要な要素です。
入力データはRecordGroupを利用したもと同一とします。
処理フロー
フロー変数
フロー変数 | データ型 | 初期値 |
---|---|---|
vWorkFolder | String | wk2 |
v発注NO | String |
【処理概要】
- ワークフォルダの削除
- headerCSVファイルの読み込みをループする
- headerレコードの発注NOをフロー変数に保存
- meisaiCSVを読み込みし、Mapperでフロー変数発注NOと同じレコードだけを移送
- 明細NOでソートを行い、HeaderCSVのストリームと合流しPDFのレコードに合わせてマッピング
- PDF生成
- フロー変数に保存された発注NOを利用しファイルの出力
最終的に明細を発注NO毎のストリームに分割する事が目的のため、今回はMapperでフィルターしてみましたが、通常のFillterコンポーネントも問題ないでしょう。PDF直前のMapperでは、Headerのストリームと明細のストリームを合流させています。
Mapper(フィルター)
このMapperでは、判定レイヤーでフロー変数「v発注NO」とレコードの発注NOを比べ、マッパー変数「判定」に移送し、移送レイヤーでは、マッパー変数「判定」がTrueのものだけを移送します。通常であればFillterコンポーネントで問題はありませんが、この方法は複雑条件やFillterコンポーネントでは指定できない条件でも簡単にフィルターできます。
マッパー変数
マッパー変数 | データ型 | 初期値 |
---|---|---|
判定 | Boolean | false |
レイヤー
レイヤー名 | レイヤー条件 |
---|---|
判定 | なし |
移送 | $local.Boolean = true |
Mapper(PDF移送)
このMapperではPDFに移送するストリームと、単一セルへの移送を行います。この様な複数入力があるMapperでは、2つの情報のストリームのレコードがそのまま参照されます。Headerストリームには1行ですので、1行目のみ、明細ストリームは明細行分参照できます。そのため、単一セルのヘッダ要素はHeaderストリームの1行目、集計後の金額などは、最終行で単一セルに移送しています。Headerストリームを合流させない場合は、発注NOと同様にヘッダーレコードのカラムをフロー変数に格納し、最終行でPDFの単一セルに移送します。
今回はヘッダーのみ存在し明細が存在しない、というケースは考慮していません。
マッパー変数
マッパー変数 | データ型 | 初期値 |
---|---|---|
小計 | Decimal | |
消費税 | Decimal |
レイヤー
レイヤー名 | レイヤー条件 |
---|---|
明細 | なし |
集計 | なし |
1行目 | $stream.RecordNo = 1 |
最終行 | $stream.RecordNo = $stream.RecordCount |
PDFコンポーネントの設定値、ファイル出力はRecordGroupフローと同一です。
最後に
2306までは、今回の様な明細をPD化する場合、キーブレイクを行いPDFコンポーネントへの入力ストリームのコントロールを行う必要がありましたが、RecordGroupコンポーネントの登場により、伝票毎のキーで分割したストリームになりますので相性は非常に良いでしょう。また従来よりもPDFコンポーネントの処理が高速になっている様な気もしますのでメモリ消費するこのコンポーネントでも構築を単純化する事で、処理負担の少ない処理が構築できるのではないかと思います。
蛇足

フローデザイナーのバージョンアップ後の最初のPDFコンポーネント利用でしたので、この画面が出てきました。また危うくテンプレートのEXCELファイルを指定してしまうところでした。危ない・・・
バージョンアップの際にはインストール直後のクライアント側作業として「EXCEL.EXE指定しておく」を忘れないうちにしておきましょう。ここで指定を間違えるとかなり面倒なので。