16. リリースノート

16.1. ver.2.3 - 2025-01-02

  • #128 依存ライブラリ Commons JEXL を v2.1からv3.4へアップデートしました。

    • 脆弱性 ELインジェクション 対策として、任意のプログラムが実行可能だったため、JEXL v3.3から導入された JexlPermissions によるEL式中で実行/参照可能なクラスなどを制限するようにしました。

    • システムプロパティ xlsmapper.jexlRestricted / xlsmapper.jexlPermissions にて、EL式の実行制限を変更することができます。詳細は、「 Javaシステムプロパティによる設定 」を参照してください。

    • 式言語の接頭語を x:f: に変更し、エラーメッセージの f: に統一しました。

      • 数式を指定するアノテーション @XlsFormula の属性 value 内で使用可能な予め登録されている関数の接頭語に影響があります。

    • MessageInterpolator にてエラーメッセージを組み立てる際に、ELインジェクションの起点とならないよう、EL式 / 変数形式は再帰的評価の対象外設定を追加しました。

      • メッセージソースのみ再帰的評価の対象とするように変更しました。

      • さらに、メッセージソースの再帰的評価の回数の上限として、最大5回までと制限を設けました。

  • #129 文字コード指定のプロパティファイルを読み込んだ時文字化けする事象を修正しました。

    • EncodingControl を使用し、UTF-8のプロパティファイルをResourceBundle経由で読み込んだ時に文字化けする事象を修正しました。

  • #130 Jakarta Bean Validation 3.0/3.1に対応しました。

  • #131 GitHub Actions にてテストビルド時する際に、タイムゾーン Asia/Tokyo を固定にしました。

  • #132 テストクラスの非推奨のimportを見直しました。

  • #133 Sphinxによるドキュメント生成環境として、DevContainer の設定を追加しました。

    • 既存のDockerの設定は削除しました。

16.2. ver.2.2 - 2022-01-01

  • #115 POIのバージョンを v5.1.0に更新しました。

    • 以前の POI v3.7 はサポート対象外となります。

    • POI v4.x でも動作しますが、@XlsCommentOption の属性 visible によるコメントの表示/非表示が正しく機能しないため注意してください。

  • #116 Hibernate Validatorのバージョンを v6.0.20.Final に更新しました。

  • #110 / #119 テスト用に使用していたライブラリを更新しました。

    • JUnitを v4.13.1 に更新しました。

    • LoggerをLog4j v1.xから、Logbackに変更しました。

  • #120 OGNLのバージョンを v3.3.1に更新しました。

16.3. ver.2.1.1 - 2021-02-13

  • #112 @XlsColumn などのアノテーションをメソッドにを付与しているとき処理対象外となる事象を修正しました。

    • 類似としてすべてのアノテーションによるシートの処理の読み込み時、書き込み時の処理のアクセッサメソッドの判定処理を追加/見直しました。

16.4. ver.2.1 - 2019-06-23

  • セルの値を取得する方法を別ライブラリ excel-cellformatter の最新版ver.0.11に対応しました。

    • 日付の書式の新元号 令和 に対応します。

  • #103 / #108 XlsMapperのメソッド getConfiguration/setConfiguration の綴り間違いを修正しました。

  • #104 セルコメントのマッピング機能を追加しました。

    • 既存のセルのマッピング時にセルコメントもマッピングできるフィールド comments を追加( シート上のコメントの取得 )。

    • @XlsComment - セルの座標を直接指定して、セルのコメントをマッピングします。

    • @XlsLablledComment - レコードの隣接するカラムをマッピングします。

    • @XlsCommentOption - 書き込み時のセルのコメントのサイズなどの制御を指定します。

16.5. ver.2.0 - 2018-06-30

  • 前提条件 を変更しました。

    • Java8以上に変更しました。Java7は非対応になります。

    • POI-3.17 に変更しました。POI-3.16以前は非対応となります。

    • BeanValidation 2.0に対応しました。

  • セルの値を取得する方法を別ライブラリ excel-cellformatter の最新版ver.0.10に対応しました。

  • マッピング可能な日時型として、以下を追加しまいた。

    • java.time.LocalDate

    • java.time.LocalTime

    • java.time.LocalDateTime

  • 隣接するセルをマッピング可能なアノテーションを追加しました。

    • @XlsArrayCells - 連続し隣接するセルを配列またはリストにマッピングします。

    • @XlsLabelledArrayCells - 見出し付きの連続し隣接するセルを配列またはリストにマッピングします。

    • @XlsArrayColumns - レコードの隣接するカラムをマッピングします。

    • @XlsArrayOption - 上記のアノテーションの書き込み時の設定を補助します。

  • 既存のアノテーションから機能を分離し、新たに以下の補助的なアノテーションを追加しました。

    • 値をトリムするアノテーション @XlsConverter(trim=true) を機能分離し、 @XlsTrim を追加しました。

    • 初期値を指摘するアノテーション @XlsConverter(defaultValue="初期値") を機能分離し、 @XlsDefaultValue を追加しました。

    • セルの書き込み時の制御設定を行うアノテーション @XlsConverter(wrapText=true, shrinkToFit=false) を機能分離し、@XlsCellOption を追加しました。

      • さらに、 @XlsCellOption において、属性 horizontalAlignverticalAlign にて、セルの横方向、縦方向の位置を指定できます。

    • レコードの書き込み時のオプションを指定するアノテーション @XlsHorizontalRecords(overRecord=..., remainedRecord=...) を機能分離し、 @XlsRecordOption を追加しました。

      • アノテーション @XlsVerticalRecords(overRecord=..., remainedRecord=...) も同様に機能分離しました。

  • @XlsHorizontalRecords/XlsVerticalRecords でレコードをマッピングする際に、データ開始位置をプログラマティックに指定できるアノテーション @XlsRecordFinder を追加しました。

  • レコードをマッピングする際に、そのレコードを除外するアノテーション @XlsIsEmpty の名称を @XlsIgnorable に変更しました。

    • さらに、レコードを除外する条件として、 @XlsHorizontalRecords(ignoreEmptyRecord=true) を指定しなくても除外するようにしました。属性 ignoreEmptyRecord は削除しました。

  • 日時型のマッピング時の書式を指定するアノテーション @XlsDateConverter の名称を @XlsDateTimeConverter に変更しました。

  • 列挙型のマッピング時の書式を指定するアノテーション @XlsEnumConverter において、属性 valueMethodName の名称を aliasName に変更しました。

  • 配列/リスト型にマッピング時の書式を指定するアノテーション @XlsArrayConverter において、属性の名称を以下に変更しました。

    • 属性の名称を itemConverterClasselementConverterClass に変更しました。

    • 属性の名称を ignoreEmptyItemignoreEmptyElement に変更しました。

    • 属性の名称を itemClasselementClass に変更しました。

    • 要素をパース/フォーマットするクラス ItemConverter の名称を ElementConverter に変更しました。 デフォルト実装クラスの名称も DefaultItemConverterDefaultElementConverter に変更しました。

  • マッピングの順番を指定するアノテーション @XlsHint(order=1) の名称を @XlsOrder に変更しました。

  • レコードをスキップするかどうか判定用のメソッドを指定するアノテーション @XlsIsEmpty の名称を @XlsIgnorable に変更しました。

  • 見出し付きセルをマッピングするアノテーション @XlsLabelledCell において、見出し用のセルが結合されているかを考慮する属性 labelMarged を追加しました。

    • 従来は、結合されていても考慮されていないため、属性 skip で結合セル分を読み飛ばしていましたが、属性 labelMarged の初期値は true となるため、動作が変わってきます。

  • 縦方向のレコードをマッピングするアノテーション @XlsVerticalRecords において、表の開始位置を指定する 属性 bottom を追加しました。

  • 繰り返す表をマッピングするアノテーション @XlsIterateTables において、以下の変更を行いました。

    • マッピング可能なクラスタイプとして java.util.Collection/java.util.Set 型に対応しました。

    • 縦方向のレコードをマッピングするアノテーション @XlsVerticalRecords に対応しました。

    • 開始位置を指定する属性 address を削除しました。

  • システム設定のプロパティ を指定するクラス XlsConfig の名称を Configuration に変更しました。さらに、以下の項目を追加しました。

    • cacheCellValueOnLoad - 読み込み時にセルの値をキャッシュして処理速度の向上を行うかどうか指定します。

    • SheetBindingErrorsFactory - マッピング時のエラー情報 SheetBindingErrors のインスタンスを作成すためのコールバック用クラスを指定します。

    • annotationMapping - XMLなどによるアノテーションのマッピング情報を設定します。

  • XMLによるマッピングの指定方法を、システム設定のプロパティで設定するよう変更しました。詳細は、XMLによるマッピング方法 を参照してください。

  • 値の検証を行うインタフェース ObjectValidatorFieldValidtor において、BeanValidationのグループに相当する機能を追加し、指定できるようにしました。

  • 値の検証の結果作成されるエラーオブジェクトをメッセージに変換するクラス SheetMessageConverter の名称を SheetErrorFormatter に変更しました。

  • 独自のクラスタイプにマッピングする方法が変更になりました。詳細は、 独自のクラスタイプの対応方法 を参照してください。

  • 独自の表をマッピングする方法の指定方法として、アノテーション @XlsFieldProcessor による方法を追加しました。詳細は、 独自の表・セルのマッピング方法 を参照してください。

  • 表・セルをマッピングする各種アノテーションに、属性 cases を追加し、読み込み時/書き込み時と任意の処理で適用すること指定できるようにしました。

  • リスナーを指定するアノテーション @XlsListener において、リスナークラスを複数指定できるようにしました。

    • さらに、属性 listenerClass の名称を value に変更し、属性名の指定を省略できるようにしました。

  • パッケージ構成を以下のように変更しました。

    • com.gh.mygreen.xlsmapper.fieldprocessor.processorcom.gh.mygreen.xlsmapper.processor.impl に変更しました。

    • com.gh.mygreen.xlsmapper.cellconverter.converter ``com.gh.mygreen.xlsmapper.converter.impl に変更しました。

    • com.gh.mygreen.xlsmapper.validation.fieldvalidationcom.gh.mygreen.xlsmapper.validation.fieldvalidation.impl に分割しました。

    • UtilやNavigator、IsEmptyBuilder クラスなどを、 com.gh.mygreen.xlsmapper.util パッケージに移動しました。

  • セルのアドレスを表現するクラス CellPosition を追加しました。

    • このクラスは、 java.io.Serializable / Comparable/Cloneable を実装しており、扱いやすくなっています。

    • さらに、各クラス java.awt.Point/org.apache.poi.ss.util.CellAddress に変換可能です。

  • 本ライブラリのルートの例外クラス XlsMapperException を 非検査例外RuntimeExceptionに変更しました。

  • フィールド情報を管理するクラス FieldAdapter の名称を FieldAccessor に変更しました。パッケージも com.gh.mygreen.xlsmapper.fieldaccessor に移動しました。

  • 複数のシートをマッピングした結果を格納するクラス SheetBingingErrorsContainer の名称を MultipleSheetBindingErrors に変更しました。

  • 実行時に出力されるメッセージを日本語化しました。

  • メッセージ定義のプロパティファイル SheetValidationMessages.properties の文字コードをUTF-8に変更し、asciiコードへの変換を不要にしました。

16.6. ver.1.6 - 2017-01-02

  • #88 POI-3.15で、クラス CellCommentStore コンパイルエラーが発生する事象を修正しました。

  • #89 JSP-EL 2.x使用時に、例外 NoClassDefFoundError が発生する事象を修正しました。

  • #90 テスタにおいて、テスト結果ファイルを書き込む場所を src/test/out から target/test_out に変更しました。

  • #91 セルの値を取得する方法を別ライブラリ excel-cellformatter の最新版ver.0.9.1に対応しました。

  • #92 POI-3.14以降で、ネストする表を出力するときに例外が発生する事象を修正しました。

  • #93 不正な数式を書き込んだときのテスタを修正しました。

    • POI-3.14以降で、POIで使用できない関数を設定したときにエラーが発生しなくなったため、数式を他のケースに変更しました。

  • #94 POI-3.15で、@XlsHorizotnalRecords において、レコードの挿入や削除を行ったレコードより下方にある結合したセルが解除される事象を修正しました。

  • #95 @XlsHorizotnalRecords において、レコードの削除を行う設定のとき、空のレコードを書き込むとデータ行が全て削除される事象を改善し、必ず、1レコードは残るように修正しました。

  • #96 POI-3.15 で、CellLinkjava.net.URL 型において、A1 形式のセルに対するリンクを書き込んだ場合、例外が発生する事象を修正しました。

16.7. ver.1.5.2 - 2016-10-30

  • #87 @XlsHorizontalRecords で書き込む際に、表の直後に文字がある場合、挿入操作をすると、直後の文字が消えてしまう事象を修正しました。

16.8. ver.1.5.1 - 2016-10-30

  • #85 PatternValidator のエラーメッセージ中に使用する変数 patternName としてパターン名を指定できるように引数を追加しました。

  • #86 入力値検証時のエラーメッセージのキーのパターンを追加しました。

    • <エラーコード>.<オブジェクト名>.<パス>.<フィールド名> の形式を追加しました。

16.9. ver.1.5.0 - 2016-08-30

  • #83 出力する際の数式を定義するアノテーション @XlsFormula を追加しました。

    • 式の制御、処理を行う システム設定のプロパティ として、formulaRecalcurationOnSaveformulaFormatter を追加しました。

    • EL式の実装である JEXL を依存ライブラリに追加しました。

    • EL2.xをスタンドアローンで呼び出せるライブラリ standalone-el の最新版ver.0.2に対応しました。

  • #84 Javadocの記述間違いを修正しました。

16.10. ver.1.4.4 - 2016-07-02

16.11. ver.1.4.3 - 2016-05-28

  • セルの値を取得する方法を別ライブラリ excel-cellformatter の最新版ver.0.8.2に対応しました。

  • Javadocやドキュメントの誤字や表現を修正しました。

16.12. ver.1.4.2 - 2016-05-07

  • バイナリに関係のないCoverturaのリンクが張られおり、実行時エラーとなったためビルドし直しました。

16.13. ver.1.4.1 - 2016-04-29

16.14. ver.1.4 - 2016-03-21

  • #79 : @XlsNestedRecords による、入れ子構造の表をマッピングする機能を追加しました。

  • セルの値を取得する方法を別ライブラリ excel-cellformatter の最新版ver.0.7に対応しました。

16.15. ver.1.3 - 2016-03-13

  • #77 : @XlsListener による、ライフサイクル・コールバック処理をリスナクラスに別途実装する機能を追加しました。

  • #78 : 複数のアノテーションが設定されている場合、1つしか処理されない事象を改善しました。

16.16. ver.1.2.1 - 2016-03-12

  • #65 : 例外時のメッセージのスペルミス、値の設定間違いを修正しました。

16.17. ver.1.2 - 2016-03-12

  • システムプロパティ skipTypeBindFailure の名称を continueTypeBindFailure に変更し、意味と名称が一致するようにしました。

  • #71 : アノテーション @XlsColumn などを付与したフィールドが、java.util.LinkedList などの具象クラスの場合をサポートしました。

  • #76 : アノテーション @XlsMapColumns に属性 nextColumnName を追加、マッピングの終了条件のセルを指定できるようにしました。

16.18. ver.1.1 - 2016-03-08

  • #3 : @XlsArrayConverter に属性 itemConverterClass を追加し、任意のクラス型を変換できるようにしました。

  • #66 : セルの値を取得する方法を別ライブラリ excel-cellformatter の最新版ver.0.6に対応しました。

  • #67 : アノテーション @XlsNumberConverter@XlsDateConverter の属性 pattern を廃止し、 読み込み用の書式の属性 javaPattern と書き込み用の書式の属性 excelPattern を追加しました。

  • #70 : アノテーションのXMLによるマッピング機能の機能追加として、XMLをJavaオブジェクトで組み立てる機能 を追加しました。 それに伴い、次の修正も行いました。

    • XML読み込み用のクラス XmlLoader の名称を XmlIO に変更し、XMLの書き込み用メソッドを追加しました。

    • 例外クラス XmlLoadException の名称を XmlOperateException に変更しました。

    • 読み込み時/書き込み時の処理対象となるシートの抽出処理を、 SheetFinder クラスに分離しました。 XlsMapperConfigのプロパティ「sheetFinder」 でカスタマイズできます。

  • #72 : ラベルや見出しを正規表現で指定、正規化してマッピングする機能を追加しました。

  • #73 : 見出し結合されている場合の属性を追加しました。

  • #74 : 型変換用のアノテーションのパッケージ ~.xlsmapper.annotation.converter~.xlsmapper.annotation に移動しました。

  • #75 : 一部のアノテーションの属性名を変更しました。

    • アノテーション @XlsHorizonalRecords@XlsVerticalRecords の属性 skipEmptyRecordignoreEmptyErecord に変更しました。

    • アノテーション @XlsConverter の属性 forceWrapTextwrapText に、属性 forceShrinkToFitshrinkToFit 変更しました。

16.19. ver.1.0a - 2015-09-23

下記の機能を追加または改善

  • #63 : 実行すると必要のないCoverturaのクラスのエラーが発生する事象を修正しました。

    • ビルドをし直しただけで、機能はver.1.0から変更ありません。

16.20. ver.1.0 - 2015-07-19

下記の機能を追加または改善

  • #14 : メッセージ中で利用可能な式言語を EL2.0/3.0、MVELの2つにしました。

    • 入力値検証で利用する CellField クラスでプロパティを指定する際に、独自の実装PropertyNavigationに切り替えました。 それに伴い、非公開のフィールドへのアクセスも可能になりました。

  • #28 : クラス java.util.Calendar に対するCellConveterを追加しました。

  • #35 : アノテーション @XlsHorizontalRecords の付与可能なクラスタイプとして、java.util.Set を追加しました。

    • 実装クラスを指定した場合は、その読み込み時には、インスタンスが設定されます。

    • アノテーション @XlsVerticalRecords も同様に修正しました。

  • #37 : アノテーション @XlsVerticalRecords でマッピングする際に、表のタイトル(ラベル)が上にある場合に対応しまいた。

    • 属性 tableLabelAbove=true を付与すると、表のタイトルの位置が上にあると前提として処理を行います。

    • さらに、表のタイトルから見出しがどれだけ離れているか指定する属性 right を追加しました。 XlsHorizontalRecords の属性 bottom に対応するものです。

  • #50 : クラス IsEmptyBuilder にて、検証対象のタイプがMap, Collection, 配列の場合、要素をチェックするように機能追加しました。要素の値が全てnullまたは空と判定できた場合は、そのオブジェクトの値が空と判定します。

    • 設定用クラス IsEmptyConfig で、要素をチェックするかなどを変更できます。

  • #53 : フィールドの入力値検証を行うためのFieldValidatorの実装である、「MaxValidator/MinValidator/RangeValidator」において、メッセージ表示用に値をフォーマットを FieldFormatter で行うように機能追加しました。

    • 標準では、DefaultFieldFormatter が設定されていますが、独自の実装に切り替えることができます。

  • #56 : AnnotationReaderで読み込むXMLに属性 override=true を定義すると、JavaクラスとXMLファイルでそれぞれに定義しているアノテーションの差分を考慮するよう機能追加しました。

  • #58 : ドキュメント 拡張方法 を記載しました。

  • #59 : アノテーション @XlsVerticalRecords/XlsSheetName の書き込み時の処理に、読み込み用のアノテーションを取得していたため、getterメソッドにアノテーションを付与していても反映されない事象を修正しました。

    • 各種CellConverterの処理時に、アノテーション @XlsConverter を付与していた場合も同様の事象を修正しました。

  • #60 : 入力値検証時にメッセージを処する際にエスケープ文字( \ ) が正しく処理されない事象を修正しました。

  • #61 : インタフェース CellConverter 中の書き込み用のメソッドの使用を整理しました。

    • @XlsMapColums を付与したフィールドの値を処理するためのメソッド toCellWithMap(...)toCell() に統合しました。

    • toCell(...) メソッドの第二引数として渡していた処理対象のオブジェクトを、Beanクラスではなく、書き込み対象の値を渡すように変更しました。

    • CellConverterRegistry, FieldProcessorRegistryで使用していないメソッドを削除しました。

16.21. ver.0.5 - 2015-06-29

下記の機能を追加または改善

  • #21 : セルの値を取得する方法を別ライブラリ excel-cellformatter の最新版ver.0.4に対応しました。

  • #22 : 内部クラス定義にてクラス定義がprivateなどの非公開の場合にも対応しました。読み込み時にインスタンスの生成に失敗する事象を改善しました。

  • #23 : 読み込み時に、文字列形式のセルをdoubleなどの数値型のクラスにマッピングする際にエラーが発生する事象を改善しました。

  • #24 : 読み込み時に、Javaクラスの表現可能な値よりも大きい数値をマッピングする際に、オーバーフローではなく、エラーとするよう動作を改善しました。

  • #25 : 日時型をマッピングする際に、日時の型変換用アノテーション @XlsDateConverter で書式を指定しないとエラーが発生する事象を改善しました。アノテーションを指定しない場合、Javaの各タイプごとにデフォルトの書式が設定されます。

    • java.util.Date の場合、デフォルトで yyyy-MM-dd HH:mm:ss の書式が適用されます。

    • java.sql.Date の場合、デフォルトで yyyy-MM-dd の書式が適用されます。

    • java.sql.Time の場合、デフォルトで yyyy-MM-dd HH:mm:ss の書式が適用されます。

    • java.sql.Timestamp の場合、デフォルトで yyyy-MM-dd HH:mm:ss.SSS の書式が適用されます。

  • #26 : 空セル(ブランクセル)をString型に読み込む時、型変換世のアノテーション @XlsConverter(trim=true) を付与してトリムを有効としている場合、空文字を設定するように改善しました。

    • トリムが無効な場合は、nullが設定されます。

  • #27 : 空の項目を無視するリスト型の型変換用アノテーション @XlsArrayConverter(ignoreEmptyItem=true) と、トリムを有効にするアノテーション @XlsConverter(trim=true) を組み合わせた場合、トリム処理が無視される事象を改善しました。

    • トリム処理により空の項目となり、空の項目を無視する設定をしている場合、その項目は読み込み、書き込みの対象外となります。

  • #28 : アノテーション @XlsLabelledCell(label="XXXX", optional=true) と設定し、指定したラベルのセルが見つからない場合に、NullPointerExceptionが発生する事象を修正しました。

  • #31 : アノテーション @XlsLabelledCell の属性 range、skip、headerLabelを指定した場合の処理を改善しました。

    • 属性headerLabelを指定した場合、Excelのシート上のheaderLabelで指定したセルを取得した後、labelで指定したセルを検索する際に、検索の開始位置が常に0行目から検索し直してしまい、違うセルがヒットしてしまう事象を修正しました。

    • 属性skipとrangeを指定していると、NullPointerExceptionが発生する事象を修正しました。

  • #32 : アノテーション @XlsLabelledCell でセルの値を読み込む時に、Map<String, Position> positions フィールドにてを定義していても、セルのアドレスが正しく取得できない事象を修正しました。

  • #33 : アノテーション @XlsSheet(number=2) で読み込み/書き込みするシートをシート番号で指定している場合、例外 SheetNotFoundException がスローされる事象を修正しました。

  • #34 : アノテーション @XlsHorizontalRecords レコードをマッピングする場合、見出しセルを結合していると正しく、セルの値が取得できない事象を修正しました。@XlsVerticalRecords も同様に修正しました。

  • #38 : 数値型をマッピングする場合、Excelの仕様に合わせて有効桁数を指定するように機能追加しました。

    • 有効桁数は、数値の型変換用アノテーション @XlsNumberConverter(precision=15) で変更可能です。

    • デフォルトでは、有効桁数はExcelの仕様と同じ15桁です。

  • #39 : 型変換用アノテーション @XlsConverter(defaultValue="aaaa") デフォルト値を指定しているが、その値自体が不正な場合、ConverterExceptionをスローしているが、その子クラスのTypeBindExceptionをスローするように修正しました。

  • #40 : char型を書き込む時に初期値'u000'を設定し書き込むとExcel上で文字化けする事象を修正しました。

    • char型を書き込む時に、’u000’は、空白と判断して、空セルとして書き込むよう修正。

    • char型の場合、書き込む時にデフォト値が2文字以上あってもそのまま書き込まれるため、先頭の1文字のみ書き込むよう修正。

  • #41 : Javaクラス java.util.Set を書き込む場合、値をnullとしていると、NullPointerExceptionが発生する事象を修正しました。

  • #42 : アノテーション @XlsVerticalRecords で属性headerAddressを指定していても反映されない事象を修正しました。

  • #44 : アノテーション XlsSheet(regexp="Sheet.+") 正規表現にてシート名を指定し、書き込む際の改善をしました。

    • 正規表現で指定しても、一致するシートが1つの場合は、エラーとしないで、そのシートに書き込む。

    • アノテーション @XlsSheetName を付与しているフィールドを指定し、その値に一致しなくても、正規表現に一致するシートが1つ一致すれば、そのシートに書き込む。

  • #45 : アノテーション @XlsHorizontalRecords(terminal=RecordTerminal.Empty) を設定している場合、レコードを設定していても、書き込まれない事象を修正しました。

    • 読み込み時には表の終端を判定する際に、セルの値が空であることに意味があるが、書き込む際にはテンプレート用のセルは空を設定しているため、処理が終了してしまう。そのため、書き込む時に、terminalの値がRecordTerminal.Emptyのとき強制的にRecordTerminal.Borderに補正して処理する。

  • #46 : アノテーション @XlsHoritonralRecords で書き込む場合、レコードのフィールドにアノテーション @XlsColumn(merged=true) を付与し、同じ値のセルを結合する設定をしていると、Excelファイルが壊れる事象を修正しました。

  • #47 : アノテーション @XlsHorizontalRecords を付与しているフィールド型が配列型の場合、書き込むときにレコードが出力されない事象を修正しました。 同様に、@XlsVertiacalRecords@XlsIterateTables の処理も修正しました。

  • #48 : アノテ-ション @XlsHorizontalRecords(remainedRecord=RemainedRecordOperate.Delete) を付与し、書き込む先に余分な行を削除するときに、1回多く削除してしまう事象を修正しました。

  • #49 : アノテーション @XlsHorizontalRecords を付与し、書き込む際にレコードが追加、削除されるときに、Excelの入力規則の範囲修正が正しくできない事象を修正しました。

  • #51 : アノテーション @XlsIterateTables を付与し、連結した表を書き込む時に、はみ出したセルがあると、属性orverRecordOperateの処理が実行されない事象を修正しました。

  • #52 : アノテーション @XlsHorizontalRecords を付与したクラスに、ライフサイクルコールバック用のアノテーション @XlsPostSave を付与したメソッドが実行されない事象を修正しました。 @XlsVerticalRecords の場合も同様に修正しました。

  • #54 : メッセージ中などの式言語の処理としてEL2.Xを利用する場合、実装を外部ライブラリ standalone-el に変更しました。

  • #57 : メッセージ中などの式言語の処理としてEL3.Xを利用している場合、formatterを利用しているとエラーが発生する事象を修正しました。

    • EL3.xのライブラリのバージョンを3.0から3.0.1-b08に変更しました。

  • アノテーション @XlsIsEmpty を付与してレコードが空かどうか判定するメソッドの実装を容易にするためのクラス IsEmptyBuilder を追加しました。

  • XMLファイルによるマッピング機能において、XMLのパースをJAXPから、JAXBへ変更しました。

16.22. ver.0.4 - 2015-04-05

下記の機能を追加または改善

  • #15 : セルの値を取得する方法を別ライブラリ excel-cellformatter を利用するよう変更。

    • XlsConfigのプロパティ POICellFormatter のクラス名を CellFormatter に変更。

    • この対策により、#19 も改善される

  • #17 : ハイパーリンクを書き込む処理を改善し、内部的に二重にリンクが設定される事象を修正。

  • #18 : コメントを含むシートをテンプレートして出力し、それをExcelで開くと警告メッセージが表示される事象を修正。

    • これは、POI-3.11の不良であり、POI-3.10~POI-3.11のみで発生する。

    • この事象を回避するために、 XlsMapperConfigのプロパティとして、「correctCellCommentOnSave」を追加。

16.23. ver.0.3 - 2015-01-11

下記の機能を追加または改善

  • #4 : 書き込み時にレコードの追加・削除を行った際に入力規則と名前の定義を自動的に修正する機能を追加。

    • XlsMapperConfigのプロパティとして、「correctNameRangeOnSave」「correctCellDataValidationOnSave」を追加。

    • ただし、データの入力規則を自動的に修正する機能を利用する場合は、POI-3.11が必要となります。

  • #13: 読み込み時のエラーメッセージの改善。型変換時エラー時にセルの値'validatedValue'を追加。

    • さらに、CellFieldを使用した値の検証のエラーメッセージの候補に、クラスタイプを指定できるよう改善。

16.24. ver.0.2.3 - 2015-01-01

下記の機能を追加または改善

  • #7 : Excel関数が設定されているセルを読み込んだときに例外が発生する事象を修正。

  • #8 : 書き込み時のセルの「縮小して表示」の処理を効率化。

  • #9 : CellFieldクラスで属性エラーがある場合でも必須チェックが実行される事象を修正。

  • #10 : 列挙型に対して入力値検証する際にエラーコード「typeMismatch.java.lang.Enum」を追加。

  • #11 : isから始まるboolean型のgetterメソッドにアノテーションを付与しても無視される事象を修正。

  • #12 : EL3.0で追加されたラムダ式を利用できるよう改善。

16.25. ver.0.2.2 - 2014-12-01

下記の不良を修正。

  • #5 : 書き込み時に、リストのトリムが有効になりません。

  • #6 : 入力値検証の際に変数の値がnullにしているとNPEが発生する。

16.26. ver.0.2.1 - 2014-11-25

下記の不良を修正。

  • #1 - @XlsHorizontalRecordsに、Set型を使用すると例外が発生する。

  • #2 - ExpressionLanguageELImplが、Spring-expression依存になっている。

16.27. ver.0.2 - 2014-11-24

  • アノテーション @XlsIsEmpty を追加しました。

    • @XlsHorizontalRecords@XlsVertialRecords の属性skipEmptyRecordで'true'を指定した場合、レコードが空の場合、そのレコードの読み込みをスキップします。

    • アノテーション @XlsIsEmptyは、引数なしで、戻り値がtrueのメソッドに付与する必要がります。

  • MessageInterpolator を改善し、メッセージ中に定義した変数をメッセージコードとして処理する機能を追加しました。

    • メッセージをフォーマットする際に、引数で渡した変数用オブジェクトに存在しない変数名がメッセージに存在する場合、MessageResolverから値を取得します。

  • SheetBindingErrors中のフィールドエラーにアクセスするメソッドにおいて、現在の位置を考慮するように改善しました。

  • @XlsHorzontalRecords(remainedRecord=RemainedRecordOperate.Clear) を指定指示に書き込んだ場合、書き込むレコードの件数が0件の場合、出力したシートがヘッダーのスタイルになる現象を修正しました。

  • @XlsHorzontalRecords(remainedRecord=RemainedRecordOperate.Delete) を指定指示に書き込んだ場合、書き込むレコードの件数が0件の場合、見出し行を除く行が全て削除される現象を改善しまいた。1件のみ残すよう修正しました。

16.28. ver.0.1 - 2014-10-30

初期リリース。