Date Documentation
- Introduction
- Header
- Construction
- Construct from String
- Construct from Clock
- Accessors
- Conversion To String
- Operators
Introduction
boost::gregorian::date クラスはライブラリユーザーにとって主要なインタフェースである。 一般に、日付クラスは代入可能ではあるが、一度構築されると不変である事が多い。
日付の生成について別の方法がdate iteratorsとdate algorithms or generatorsに含まれている。
Header
#include "boost/date_time/gregorian/gregorian.hpp" //全ての型とI/Oを含む
もしくは
#include "boost/date_time/gregorian/gregorian_types.hpp" //型のみでI/Oは含まない
Construction
| Syntax | Description | Example |
|---|---|---|
date(greg_year year, greg_month month, greg_day day) | 日付の要素から構築する。year, month, day の範囲が不正な場合、それぞれ std::out_of_range から派生した bad_year, bad_day_of_month, bad_day_month 例外を投げる。 | date d(2002,Jan,10) |
date(date d) | コピーコンストラクタ | date d1(d) |
date(special_values sv) | 無限大、無効値(not-a-date-time)、最大値、最小値を構築するコンストラクタ | date d1(neg_infin);date d2(pos_infin);date d3(not_a_date_time);date d4(max_date);date d5(min_date); |
Construction From String
| Syntax | Description | Example |
|---|---|---|
date from_string(const std::string&) | 年-月-日の順に区切られた文字列から 例:2002-1-25 | std::string ds("2002/1/25");date d(from_string(ds)) |
date from_undelimited_string(const std::string&) | 年-月-日の順のISO形式から 例:20020125 | std::string ds("20020125");date d(from_string(ds)) |
Construction From Clock
| Syntax | Description | Example |
|---|---|---|
day_clock::local_day() | 計算機に設定された時間帯に準じた地域時間を取得する | date d(day_clock::local_day()) |
day_clock::universal_day() | UTC 標準時を取得する | date d(day_clock::universal_day()) |
Accessors
| Syntax | Description | Example |
|---|---|---|
greg_year year() const | 年の部分を取得 | date d(2002,Jan,10); d.year() --> 2002; |
greg_month month() const | 月の部分を取得 | date d(2002,Jan,10); d.month() --> 1; |
greg_day day() const | 日の部分を取得 | date d(2002,Jan,10); d.day() --> 10; |
greg_ymd year_month_day() const | greg_ymd 構造体を返す日付の3つの要素全てが必要なときに便利である | date d(2002,Jan,10);date::ymd_type ymd = d.year_month_day(); ymd.year --> 2002, ymd.month --> 1, ymd.day --> 10 |
greg_day_of_week day_of_week() const | 曜日を返す(例: Sunday, Monday, etc. | date d(2002,Jan,10); d.day() --> Thursday; |
bool is_infinity() const | 日付が正または負の無限大の時 true を返す | date d(pos_infin); d.is_infinity() --> true; |
bool is_neg_infinity() const | 日付が負の無限大の時 true を返す | date d(neg_infin); d.is_neg_infinity() --> true; |
bool is_pos_infinity() const | 日付が正の無限大の時 true を返す | date d(neg_infin); d.is_pos_infinity() --> true; |
bool is_not_a_date() const | 日付が無効値(not a date)の時 true を返す | date d(not_a_date_time); d.is_not_a_date() --> true; |
Conversion To String
| Syntax | Description | Example |
|---|---|---|
std::string to_simple_string(date d) | YYYY-mmm-DD (mmm は月名の3文字短縮形)形式に変換 | 2002-Jan-01 |
std::string to_iso_string(date d) | YYYYMMDD 形式に変換 | 20020131 |
std::string to_iso_extended_string(date d) | YYYY-MM-DD 形式に変換 | 2002-01-31 |
Operators
| Syntax | Description | Example |
|---|---|---|
operator<< | ストリーム出力演算子 | date d(2002,Jan,1);std::cout << d << std::endl; |
operator==, operator!=,operator>, operator<,operator>=, operator<= | サポートする比較演算子 | d1 == d2, etc |
date operator+(date_duration) const | オフセット日数 date_duration を加えた日付を返す | date d(2002,Jan,1);date_duration dd(1);date d2 = d + dd; |
date operator-(date_duration) const | オフセット日数 date_duration を差し引いた日付を返す | date d(2002,Jan,1);date_duration dd(1);date d2 = d - dd; |
date_duration operator-(date) const | 2つの日付を差し引いた日数(date duration)を返す | date d1(2002,Jan,1);date d2(2002,Jan,2);date_duration dd = d2-d1; |
Last modified: Wed Aug 28 17:52:03 MST 2002 by Jeff Garland © 2000-2002
Japanese Translation Copyright (C) 2003 Shoji Shinohara.