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.