メイン コンテンツをスキップする

TalendDateルーチン

[TalendDate]ルーチンには、さまざまな種類の操作を実行し、日付式の形式について確認できるファンクションが複数含まれています。

情報メモ警告: パターンがyyyy-MM-ddyyyy-MM-dd HH:mm:ssに設定されている場合を除き、これらのファンクションでは内部でSimpleDateFormatというJavaクラスが使用されています。この場合、パフォーマンス向上のため、入力された日付文字列の形式チェックは行われません。この2つのパターンのいずれかを使う場合は、入力された日付文字列が、設定されたパターンと正確に一致することを確認する必要があります。

[Repository] (リポジトリー)ツリービューにあるシステムルーチンフォルダーの下の[TalendDate]ノードをダブルクリックすると、これらのファンクションにアクセスできます。

TalendDateルーチンのファンクション

ファンクション

説明

構文

addDate

n日、nか月、n時間、n分またはn秒をJavaの日付に追加し、新しい日付を返します。

日付形式は:yyyyMMddHHmmssSSSです。

TalendDate.addDate("initial date string", ["date format - eg.: yyyy/MM/dd"], integer n,"format of the part of the date to which n is to be added - eg.:yyyy").

compareDate

指定した形式に従って2つの日付のすべての部分を比較します。日付が同一の場合は0を、最初の日付が早い場合は-1を、2番目の日付が早い場合は1を返します。

patternパラメーターは日付形式(たとえば、"yyyy-mm-dd")を指定します。

TalendDate.compareDate(Date date1, Date date2,[String pattern])

diffDate

指定した比較パラメーターに従って、年、月、日、時間、分、秒またはミリ秒に関して2つの日付の差を返します。

dateTypeパラメーターは、比較される日付部分の形式を指定します。有効値は、"yyyy""MM""dd""HH""mm""ss""SSS"です。デフォルト値は"dd"です。

ignoreDSTパラメーターは、DST(夏時間)を考慮する必要があるかどうかを指定します。

TalendDate.diffDate(Date date1, Date date2,[String dateType],[boolean ignoreDST])

たとえば、TalendDate.diffDate(TalendDate.parseDate("yyyy-MM-dd", "2022-12-01"), TalendDate.parseDate("yyyy-MM-dd", "2022-10-02"), "MM")2を返します。

diffDateFloor

指定した比較パラメーターに従って、年または月に関して2つの日付の差を返します。値は最も近い整数に切り捨てられます。

dateTypeパラメーターは、比較される日付部分の形式を指定します。有効値は"yyyy""MM"です。

TalendDate.diffDateFloor(Date date1, Date date2, String dateType)

たとえば、TalendDate.diffDateFloor(TalendDate.parseDate("yyyy-MM-dd", "2022-12-01"), TalendDate.parseDate("yyyy-MM-dd", "2022-10-02"), "MM")1を返します。

diffDateIgnoreDST

指定した比較パラメーターに従って、DSTを無視して、日、月、または年に関して2つの日付間の差を返します。

dateTypeパラメーターは、比較される日付部分の形式(たとえば、"yyyy")を指定します。

TalendDate.diffDateIgnoreDST(Date1(), Date2(),[String dateType])

formatDate

指定した形式に対応する日付文字列を返します。

TalendDate.formatDate("date format - eg.: yyyy-MM-dd HH:mm:ss", Date() to be formatted)

formatDateInTimeZone

特定のタイムゾーンで、日付を特定の形式(日時文字列)にフォーマットします。

TalendDate.formatDateInTimeZone(String datePattern, Date tate, String TimeZoneID)

formatDateInUTC

UTCタイムゾーンで、日付を特定の形式(日時文字列)にフォーマットします。

TalendDate.formatDateInUTC(String datePattern, Date tate, String TimeZoneID)

formatDateLocale

対象の国で使用されている形式に従って、日付を日付/時間文字列に変更します。

TalendDate.formatDateLocale("format target", java.util.Date date, "language or country code")

formatDatetimeoffset

(yyyy-MM-dd HH:mm:ss.SSSXXX)というローカルタイムゾーン形式(JDK7がサポート)であるMSSQL 2008タイプのdatetimeoffset ISO 8601文字列に日付をフォーマットします。

TalendDate.formatDatetimeoffset(Date date)

getCurrentDate

現在の日付を返します。入力パラメーターは必要ありません。

TalendDate.getCurrentDate()

getDate

指定された形式(オプション)で現在の日付と時間を返します。この文字列には、固定文字列または日付にリンクされた変数を含めることができます。デフォルトでは、文字列はDD/MM/CCYYの形式で返されます。

TalendDate.getDate("Format of the string - ex: CCYY-MM-DD")

getFirstDayOfMonth

イベントの日付を現在の月の初日に変更し、新しい日付を返します。

TalendDate.getFirstDayMonth(Date)

getLastDayOfMonth

イベントの日付を現在の月の末日に変更し、新しい日付を返します。

TalendDate.getLastDayMonth(Date)

getPartOfDate

指定した形式に従って日付の一部を返します。この文字列には、固定文字列または日付にリンクされた変数を含めることができます。

TalendDate.getPartOfDate("String indicating the part of the date to be retrieved, "String in the format of the date to be parsed")

getRandomDate

ISO形式でランダムな日付を返します。

TalendDate.getRandomDate("format date of the character string", String minDate, String maxDate)

isDate

日付文字列が指定した形式に対応しているかどうかを確認します。結果に従って、trueまたはfalseのBoolean値を返します。

TalendDate.isDate(Date() to be checked, String pattern, [boolean ignoreTimeZone])

このpatternによって、チェックする日付の形式が指定されます。例: yyyy-MM-dd HH:mm:ss

isDateStrict

厳密なルールを使って、正しいパータンの日付として文字列値をテストします。この検証はJava 8タイムツールを使用します。タイムゾーンオフセットの範囲は-18:00から18:00までに制限されています。stringDateが正しいパターンの日付文字列であるかどうかを示すブール値を返します。

TalendDate.isDateStrict(String stringDate, String pattern)

parseDate

文字列を日付に変更します。指定された形式で日付を返します。

TalendDate.parseDate("format date of the string to be parsed", "string in the format of the date to be parsed",["boolean about whether parsing is set to be lenient, that is to say, accepting the heuristic match with the format"])

parseDateInUTC

文字列をUTCの日付に変更します。UTC形式で日付を返します。

本番環境で実行しているビッグデータジョブでは、異なるタイムゾーンで設置されている複数のマシンが関わるため、日時解析の正しい出力を確実に行うために、常にこのルーチンを使用する必要があります。

TalendDate.parseDateInUTC("format date of the string to be parsed", "string in the format of the date to be parsed", ["boolean about whether parsing is set to be lenient, that is to say, accepting the heuristic match with the format"])

parseDateLocale

指定した形式に従って文字列を解析し、日付を抽出します。指定したローカル形式に従って日付を返します。

TalendDate.parseDateLocale("date format of the string to be parsed", "String in the format of the date to be parsed", "code corresponding to the country or language")

setDate

指定した日付の部分と値および指定した形式に従って日付の一部を変更します。

TalendDate.setDate(Date, whole n, "format of the part of the date to be modified - eg.:yyyy")

TO_CHAR

日付を文字列に変換します。

TalendDate.TO_CHAR(date[,format])

  • [date] (日付): 文字列に変換する日付の値。
  • [format] (形式): 戻り値の形式を定義する文字列。

TO_DATE

文字列を日付/時刻のデータ型に変換します。

TalendDate.TO_DATE(string[, format])

  • [string] (文字列): 日付/時刻のデータ型に変換する文字列。
  • [format] (形式): string引数の一部に一致する形式文字列。指定されていない場合、stringの値はMM/dd/yyyy HH:mm:ss.SSSという日付形式であることが必要です。

たとえば、TalendDate.TO_DATE("04/24/2017 13:55:42.123")によりMon Apr 24 13:55:42 CST 2017が返されます。

ADD_TO_DATE

日時の値の一部に指定の数量を追加し、ユーザーがファンクションに渡す日付と同じ形式で日付を返します。

TalendDate.ADD_TO_DATE(date, format, amount)

  • [date] (日付): 変更する日付の値。
  • [format] (形式): 変更する日付の値の一部を指定する形式文字列。
    • 年に使用できる有効な形式文字列: YYYYYYYYYY
    • 月に使用できる有効な形式文字列: MONTHMMMON
    • 日に使用できる有効な形式文字列: DDDDDDDAYDY
    • 時に使用できる有効な形式文字列: HHHH12HH24
    • 分に使用できる有効な形式文字列: MI
    • 秒に使用できる有効な形式文字列: SS
    • ミリ秒に使用できる有効な形式文字列: MS
  • [amount] (数量): 日付の値の変更に使用する年、月、日、時などの数を指定する整数値。

例:

TalendDate.getCurrentDate()Mon Apr 24 14:26:03 CST 2017が返される場合、

TalendDate.ADD_TO_DATE(TalendDate.getCurrentDate(), "YY", 1)ではTue Apr 24 14:26:03 CST 2018が返されます。

情報メモ警告:

日付形式の"yyyy"と"YYYY"は大半の場合、同じ年の数字を返しますが、"YYYY"が次の位置で使われると想定どおりに機能しないことがあります。

  • 年の最初の週。年が週の最初の日で開始しない場合。
  • 年の最後の週。年が週の最後の日で終了しない場合。

たとえば、2016年1月2日の3日前の日付がどうなるかを計算する場合、次のコードは間違った日付を返します。

System.out.println(TalendDate.formatDate("YYYY-MM-dd", TalendDate.addDate(TalendDate.TO_DATE("01/02/2016 08:10:30.123"), -3, "dd")));

他方、次のコードは想定どおりに機能します。

System.out.println(TalendDate.formatDate("yyyy-MM-dd", TalendDate.addDate(TalendDate.TO_DATE("01/02/2016 08:10:30.123"), -3, "dd")));

したがって、通常は"yyyy"を使用してください。これは暦年を表します。

このページは役に立ちましたか?

このページまたはコンテンツにタイポ、ステップの省略、技術的エラーなどの問題が見つかった場合はお知らせください。