"datetime" --- 基本的な日付型および時間型
*****************************************

**ソースコード:** Lib/datetime.py

======================================================================

"datetime" モジュールは、日付や時刻を操作するためのクラスを提供してい
ます。

日付や時刻に対する算術がサポートされている一方、実装では出力のフォーマ
ットや操作のための効率的な属性の抽出に重点を置いています。

参考:

  "calendar" モジュール
     汎用のカレンダー関連関数。

  "time" モジュール
     時刻へのアクセスと変換。

  Module "zoneinfo"
     Concrete time zones representing the IANA time zone database.

  dateutil パッケージ
     拡張タイムゾーンと構文解析サポートのあるサードパーティーライブラ
     リ。


Aware オブジェクトと Naive オブジェクト
=======================================

日時のオブジェクトは、それらがタイムゾーンの情報を含んでいるかどうかに
よって "aware" あるいは "naive" に分類されます。

タイムゾーンや夏時間の情報のような、アルゴリズム的で政治的な適用可能な
時間調節に関する知識を持っているため、 **aware** オブジェクトは他の
aware オブジェクトとの相対関係を特定できます。 aware オブジェクトは解
釈の余地のない特定の実時刻を表現します。 [1]

**naive** オブジェクトには他の日付時刻オブジェクトとの相対関係を把握す
るのに足る情報が含まれません。あるプログラム内の数字がメートルを表わし
ているのか、マイルなのか、それとも質量なのかがプログラムによって異なる
ように、naive オブジェクトが協定世界時 (UTC) なのか、現地時間なのか、
それとも他のタイムゾーンなのかはそのプログラムに依存します。Naive オブ
ジェクトはいくつかの現実的な側面を無視してしまうというコストを無視すれ
ば、簡単に理解でき、うまく利用することができます。

aware オブジェクトを必要とするアプリケーションのために、 "datetime" と
"time" オブジェクトは追加のタイムゾーン情報の属性 "tzinfo" を持ちます
。 "tzinfo" には抽象クラス "tzinfo" のサブクラスのインスタンスを設定で
きます。 これらの "tzinfo" オブジェクトは UTC 時間からのオフセットやタ
イムゾーンの名前、夏時間が実施されるかどうかの情報を保持しています。

ただ一つの具象 "tzinfo" クラスである "timezone" クラスが "datetime" モ
ジュールで提供されています。 "timezone" クラスは、UTCからのオフセット
が固定である単純なタイムゾーン（例えばUTCそれ自体）、および北アメリカ
における東部標準時（EST）／東部夏時間（EDT）のような単純ではないタイム
ゾーンの両方を表現できます。より深く詳細までタイムゾーンをサポートする
かはアプリケーションに依存します。世界中の時刻の調整を決めるルールは合
理的というよりかは政治的なもので、頻繁に変わり、UTC を除くと都合のよい
基準というものはありません。


定数
====

"datetime" モジュールでは以下の定数を公開しています:

datetime.MINYEAR

   "date" や "datetime" オブジェクトで許されている、年を表現する最小の
   数字です。 "MINYEAR" は "1" です。

datetime.MAXYEAR

   "date" や "datetime" オブジェクトで許されている、年を表現する最大の
   数字です。 "MAXYEAR" は "9999" です。


利用可能なデータ型
==================

class datetime.date

   理想的な naive な日付で、これまでもこれからも現在のグレゴリオ暦
   (Gregorian calender) が有効であることを仮定しています。 属性は
   "year", "month",および "day" です。

class datetime.time

   理想的な時刻で、特定の日から独立しており、毎日が厳密に 24*60*60 秒
   であると仮定しています。("うるう秒: leap seconds" の概念はありませ
   ん。) 属性は "hour", "minute", "second", "microsecond", および
   "tzinfo" です。

class datetime.datetime

   日付と時刻を組み合わせたものです。 属性は "year", "month", "day",
   "hour", "minute", "second", "microsecond", および "tzinfo" です。

class datetime.timedelta

   "date", "time", あるいは "datetime" クラスの二つのインスタンス間の
   時間差をマイクロ秒精度で表す経過時間値です。

class datetime.tzinfo

   タイムゾーン情報オブジェクトの抽象基底クラスです。 "datetime" およ
   び "time" クラスで用いられ、カスタマイズ可能な時刻修正の概念 (たと
   えばタイムゾーンや夏時間の計算) を提供します。

class datetime.timezone

   "tzinfo" 抽象基底クラスを UTC からの固定オフセットとして実装するク
   ラスです。

   バージョン 3.2 で追加.

これらの型のオブジェクトは変更不可能 (immutable) です。

サブクラスの関係は以下のようになります:

   object
       timedelta
       tzinfo
           timezone
       time
       date
           datetime


共通の特徴
----------

"date" 型、"datetime" 型、"time" 型、"timezone" 型には共通する特徴があ
ります:

* これらの型のオブジェクトは変更不可能 (immutable) です。

* これらの型のオブジェクトはハッシュ可能であり、辞書のキーとして使える
  ことになります。

* これらの型のオブジェクトは "pickle" モジュールを利用して効率的な
  pickle 化をサポートしています。


オブジェクトが Aware なのか Naive なのかの判断
----------------------------------------------

"date" 型のオブジェクトは常に naive です。

"time" 型あるいは "datetime" 型のオブジェクトは aware か naive のどち
らかです。

次の条件を両方とも満たす場合、 "datetime" オブジェクト *d* は aware で
す:

1. "d.tzinfo" が "None" でない

2. "d.tzinfo.utcoffset(d)" が "None" を返さない

どちらかを満たさない場合は、 *d* は naive です。

次の条件を両方とも満たす場合、 "time" オブジェクト *t* は aware です:

1. "t.tzinfo" が "None" でない

2. "t.tzinfo.utcoffset(None)" が "None" を返さない

どちらかを満たさない場合は、 *t* は naive です。

aware なオブジェクトと naive なオブジェクトの区別は "timedelta" オブジ
ェクトにはあてはまりません。


"timedelta" オブジェクト
========================

"timedelta" オブジェクトは経過時間、すなわち二つの日付や時刻間の差を表
します。

class datetime.timedelta(days=0, seconds=0, microseconds=0, milliseconds=0, minutes=0, hours=0, weeks=0)

   全ての引数がオプションで、デフォルト値は "0" です。 引数は整数、浮
   動小数点数でもよく、正でも負でもかまいません。

   *days*, *seconds*, *microseconds* だけが内部的に保持されます。 引数
   は以下のようにして変換されます:

   * 1 ミリ秒は 1000 マイクロ秒に変換されます。

   * 1 分は 60 秒に変換されます。

   * 1 時間は 3600 秒に変換されます。

   * 1 週間は 7 日に変換されます。

   さらに、値が一意に表されるように days, seconds, microseconds が以下
   のように正規化されます

   * "0 <= microseconds < 1000000"

   * "0 <= seconds < 3600*24" (一日中の秒数)

   * "-999999999 <= days <= 999999999"

   次の例は、 *days*, *seconds*, *microseconds* に加えて任意の引数がど
   う "集約" され、最終的に3つの属性に正規化されるかの説明をしています
   :

      >>> from datetime import timedelta
      >>> delta = timedelta(
      ...     days=50,
      ...     seconds=27,
      ...     microseconds=10,
      ...     milliseconds=29000,
      ...     minutes=5,
      ...     hours=8,
      ...     weeks=2
      ... )
      >>> # Only days, seconds, and microseconds remain
      >>> delta
      datetime.timedelta(days=64, seconds=29156, microseconds=10)

   引数のいずれかが浮動小数点であり、小数のマイクロ秒が存在する場合、
   小数のマイクロ秒は全ての引数から一度取り置かれ、それらの和は最近接
   偶数のマイクロ秒に丸められます。浮動小数点の引数がない場合、値の変
   換と正規化の過程は厳密な (失われる情報がない) ものとなります。

   日の値を正規化した結果、指定された範囲の外側になった場合には、
   "OverflowError" が送出されます。

   負の値を正規化すると、最初は混乱するような値になります。例えば:

      >>> from datetime import timedelta
      >>> d = timedelta(microseconds=-1)
      >>> (d.days, d.seconds, d.microseconds)
      (-1, 86399, 999999)

以下にクラス属性を示します:

timedelta.min

   最小の値を表す "timedelta" オブジェクトで、 "timedelta(-999999999)"
   です。

timedelta.max

   最大の値を表す "timedelta" オブジェクトで、
   "timedelta(days=999999999, hours=23, minutes=59, seconds=59,
   microseconds=999999)" です。

timedelta.resolution

   "timedelta" オブジェクトが等しくならない最小の時間差で、
   "timedelta(microseconds=1)" です。

正規化のために、 "timedelta.max" > "-timedelta.min" となるので注意して
ください。 "-timedelta.max" は "timedelta" オブジェクトとして表現する
ことができません。

インスタンスの属性 (読み出しのみ):

+--------------------+----------------------------------------------+
| 属性               | 値                                           |
|====================|==============================================|
| "days"             | 両端値を含む -999999999 から 999999999 の間  |
+--------------------+----------------------------------------------+
| "seconds"          | 両端値を含む 0 から 86399 の間               |
+--------------------+----------------------------------------------+
| "microseconds"     | 両端値を含む 0 から 999999 の間              |
+--------------------+----------------------------------------------+

サポートされている演算を以下に示します:

+----------------------------------+-------------------------------------------------+
| 演算                             | 結果                                            |
|==================================|=================================================|
| "t1 = t2 + t3"                   | *t2* と *t3* の和。演算後、*t1*-*t2* == *t3* お |
|                                  | よび *t1*-*t3* == *t2* は真になります。(1)      |
+----------------------------------+-------------------------------------------------+
| "t1 = t2 - t3"                   | *t2* と *t3* の差分です。演算後、 *t1* == *t2*  |
|                                  | - *t3* および *t2* == *t1* + *t3* は真になりま  |
|                                  | す。 (1)(6)                                     |
+----------------------------------+-------------------------------------------------+
| "t1 = t2 * i または t1 = i * t2" | 時間差と整数の積。演算後、*t1* // i == *t2* は  |
|                                  | "i != 0" であれば真とな ります。                |
+----------------------------------+-------------------------------------------------+
|                                  | 一般的に、*t1* * i == *t1* * (i-1) + *t1* は真  |
|                                  | となります。(1)                                 |
+----------------------------------+-------------------------------------------------+
| "t1 = t2 * f" または "t1 = f *   | 時間差と浮動小数点の積。結果は最近接偶数への丸  |
| t2"                              | めを利用して最も近い timedelta.resolution の倍  |
|                                  | 数に丸められます。                              |
+----------------------------------+-------------------------------------------------+
| "f = t2 / t3"                    | *t2* を *t3* で除算 (3) したもの。"float" オブ  |
|                                  | ジェクトを返します。                            |
+----------------------------------+-------------------------------------------------+
| "t1 = t2 / f" または "t1 = t2 /  | 時間差を浮動小数点や整数で除したもの。結果は最  |
| i"                               | 近接偶数への丸めを利用し て最も近い             |
|                                  | timedelta.resolution の倍数に丸められます。     |
+----------------------------------+-------------------------------------------------+
| "t1 = t2 // i" または "t1 = t2   | floor が計算され、余りは (もしあれば) 捨てられ  |
| // t3"                           | ます。後者の場合、整数が 返されます。(3)        |
+----------------------------------+-------------------------------------------------+
| "t1 = t2 % t3"                   | 剰余が "timedelta" オブジェクトとして計算されま |
|                                  | す。(3)                                         |
+----------------------------------+-------------------------------------------------+
| "q, r = divmod(t1, t2)"          | 商と剰余が計算されます: "q = t1 // t2" (3) と   |
|                                  | "r = t1 % t2" 。q は整数 で r は "timedelta" オ |
|                                  | ブジェクトです。                                |
+----------------------------------+-------------------------------------------------+
| "+t1"                            | 同じ値を持つ "timedelta" オブジェクトを返します |
|                                  | 。(2)                                           |
+----------------------------------+-------------------------------------------------+
| "-t1"                            | "timedelta"(-*t1.days*, -*t1.seconds*,          |
|                                  | -*t1.microseconds*)、および *t1** -1 と同じです |
|                                  | 。 (1)(4)                                       |
+----------------------------------+-------------------------------------------------+
| "abs(t)"                         | "t.days >= 0" のときには +*t*, "t.days < 0" の  |
|                                  | ときには -*t* となります 。(2)                  |
+----------------------------------+-------------------------------------------------+
| "str(t)"                         | "[D day[s], ][H]H:MM:SS[.UUUUUU]" という形式の  |
|                                  | 文字列を返します。"t" が 負の値の場合は "D" は  |
|                                  | 負の値となります。(5)                           |
+----------------------------------+-------------------------------------------------+
| "repr(t)"                        | "timedelta" オブジェクトの文字列表現を返します  |
|                                  | 。その文字列は、正規の属 性値を持つコンストラク |
|                                  | タ呼び出しのコードになっています。              |
+----------------------------------+-------------------------------------------------+

注釈:

1. この演算は正確ですが、オーバフローするかもしれません。

2. この演算は正確であり、オーバフローし得ません。

3. 0 による除算は "ZeroDivisionError" を送出します。

4. -*timedelta.max* は "timedelta" オブジェクトで表現することができま
   せん。

5. "timedelta" オブジェクトの文字列表現は内部表現に類似した形に正規化
   されます。そのため負の timedelta は少し変な結果になります。例えば:

      >>> timedelta(hours=-5)
      datetime.timedelta(days=-1, seconds=68400)
      >>> print(_)
      -1 day, 19:00:00

6. t3 が "timedelta.max" のときを除けば、式 "t2 - t3" は常に、式 "t2 +
   (-t3)" と同等です。t3 が "timedelta.max" の場合、前者の式は結果の値
   が出ますが、後者はオーバーフローを起こします。

上に列挙した操作に加え "timedelta" オブジェクトは "date" および
"datetime" オブジェクトとの間で加減算をサポートしています (下を参照し
てください)。

バージョン 3.2 で変更: "timedelta" オブジェクトの別の "timedelta" オブ
ジェクトによる、切り捨て除算と真の除算、および剰余演算と "divmod()" 関
数がサポートされるようになりました。 "timedelta" オブジェクトと
"float" オブジェクトの真の除算と掛け算がサポートされるようになりました
。

"timedelta" オブジェクトどうしの比較が、注意書き付きでサポートされまし
た。

"==" および "!=" の比較は、比較されているオブジェクトの型が何であれ、
*常に* "bool" を返します:

   >>> from datetime import timedelta
   >>> delta1 = timedelta(seconds=57)
   >>> delta2 = timedelta(hours=25, seconds=2)
   >>> delta2 != delta1
   True
   >>> delta2 == 5
   False

("<" and ">" などの) それ以外の全ての比較で、 "timedelta" オブジェクト
を異なる型のオブジェクトと比較したときは "TypeError" が送出されます:

   >>> delta2 > delta1
   True
   >>> delta2 > 5
   Traceback (most recent call last):
     File "<stdin>", line 1, in <module>
   TypeError: '>' not supported between instances of 'datetime.timedelta' and 'int'

ブール演算コンテキストでは、 "timedelta" オブジェクトは "timedelta(0)"
に等しくない場合かつそのときに限り真となります。

インスタンスメソッド:

timedelta.total_seconds()

   この期間に含まれるトータルの秒数を返します。"td /
   timedelta(seconds=1)" と等価です。 秒以外の期間の単位では、直接に除
   算する形式 (例えば "td / timedelta(microseconds=1)") が使われます。

   非常に長い期間 (多くのプラットフォームでは270年以上) については、こ
   のメソッドはマイクロ秒の精度を失うことがあることに注意してください
   。

   バージョン 3.2 で追加.


使用例: "timedelta"
-------------------

正規化の追加の例です:

   >>> # Components of another_year add up to exactly 365 days
   >>> from datetime import timedelta
   >>> year = timedelta(days=365)
   >>> another_year = timedelta(weeks=40, days=84, hours=23,
   ...                          minutes=50, seconds=600)
   >>> year == another_year
   True
   >>> year.total_seconds()
   31536000.0

"timedelta" の計算の例です:

   >>> from datetime import timedelta
   >>> year = timedelta(days=365)
   >>> ten_years = 10 * year
   >>> ten_years
   datetime.timedelta(days=3650)
   >>> ten_years.days // 365
   10
   >>> nine_years = ten_years - year
   >>> nine_years
   datetime.timedelta(days=3285)
   >>> three_years = nine_years // 3
   >>> three_years, three_years.days // 365
   (datetime.timedelta(days=1095), 3)


"date" オブジェクト
===================

"date" オブジェクトは、両方向に無期限に拡張された現在のグレゴリオ暦と
いう理想化された暦の日付 (年月日) を表します。

1 年 1 月 1 日は日番号 1、1 年 1 月 2 日は日番号 2 と呼ばれ、他も同様
です。 [2]

class datetime.date(year, month, day)

   全ての引数が必須です。 引数は整数で、次の範囲に収まっていなければな
   りません:

   * "MINYEAR <= year <= MAXYEAR"

   * "1 <= month <= 12"

   * "1 <= day <= 指定された月と年における日数"

   範囲を超えた引数を与えた場合、 "ValueError" が送出されます。

他のコンストラクタ、および全てのクラスメソッドを以下に示します:

classmethod date.today()

   現在のローカルな日付を返します。

   "date.fromtimestamp(time.time())" と等価です。

classmethod date.fromtimestamp(timestamp)

   "time.time()" で返されるような POSIX タイムスタンプに対応するローカ
   ルな日付を返します。

   timestamp がプラットフォームの C 関数 "localtime()" がサポートする
   値の範囲から外れていた場合、 "OverflowError" を送出するかもしれませ
   ん。また "localtime()" 呼び出しが失敗した場合には "OSError" を送出
   するかもしれません。この範囲は通常は 1970 年から 2038 年までに制限
   されています。タイムスタンプの表記にうるう秒を含める非 POSIX なシス
   テムでは、うるう秒は "fromtimestamp()" では無視されます。

   バージョン 3.3 で変更: timestamp がプラットフォームの C 関数
   "localtime()" のサポートする値の範囲から外れていた場合、
   "ValueError" ではなく "OverflowError" を送出するようになりました。
   "localtime()" の呼び出し失敗で "ValueError" ではなく "OSError" を送
   出するようになりました。

classmethod date.fromordinal(ordinal)

   先発グレゴリオ暦による序数に対応する日付を返します。 1 年 1 月 1 日
   が序数 1 となります。

   "1 <= ordinal <= date.max.toordinal()" でない場合、 "ValueError" が
   送出されます。 任意の日付 *d* に対し、
   "date.fromordinal(d.toordinal()) == d" となります。

classmethod date.fromisoformat(date_string)

   "YYYY-MM-DD" という書式で与えられた *date_string* に対応する "date"
   を返します

      >>> from datetime import date
      >>> date.fromisoformat('2019-12-04')
      datetime.date(2019, 12, 4)

   この関数は "date.isoformat()" の逆関数です。 "YYYY-MM-DD" という書
   式のみをサポートしています。

   バージョン 3.7 で追加.

classmethod date.fromisocalendar(year, week, day)

   年月日で指定された ISO 暦の日付に対応する "date" を返します。 この
   関数は "date.isocalendar()" 関数の逆関数です。

   バージョン 3.8 で追加.

以下にクラス属性を示します:

date.min

   表現できる最も古い日付で、"date(MINYEAR, 1, 1)" です。

date.max

   表現できる最も新しい日付で、"date(MAXYEAR, 12, 31)" です。

date.resolution

   等しくない日付オブジェクト間の最小の差で、"timedelta(days=1)" です
   。

インスタンスの属性 (読み出しのみ):

date.year

   両端値を含む "MINYEAR" から "MAXYEAR" までの値です。

date.month

   両端値を含む 1 から 12 までの値です。

date.day

   1 から与えられた月と年における日数までの値です。

サポートされている演算を以下に示します:

+---------------------------------+------------------------------------------------+
| 演算                            | 結果                                           |
|=================================|================================================|
| "date2 = date1 + timedelta"     | *date2* は *date1* から "timedelta.days" 日だ  |
|                                 | け移動した日付です。(1)                        |
+---------------------------------+------------------------------------------------+
| "date2 = date1 - timedelta"     | "date2 + timedelta == date1" であるような日付  |
|                                 | *date2* を計算します。 (2)                     |
+---------------------------------+------------------------------------------------+
| "timedelta = date1 - date2"     | (3)                                            |
+---------------------------------+------------------------------------------------+
| "date1 < date2"                 | *date1* が時刻として *date2* よりも前を表す場  |
|                                 | 合に、*date1* は *date2* よりも小さいと見なさ  |
|                                 | れます。(4)                                    |
+---------------------------------+------------------------------------------------+

注釈:

1. *date2* は、 "timedelta.days > 0" の場合は進む方向に、
   "timedelta.days < 0" の場合は戻る方向に移動します。 演算後は "date2
   - date1 == timedelta.days" が成立します。 "timedelta.seconds" およ
   び "timedelta.microseconds" は無視されます。 "date2.year" が
   "MINYEAR" になってしまったり、 "MAXYEAR" より大きくなってしまう場合
   には "OverflowError" が送出されます。

2. "timedelta.seconds" と "timedelta.microseconds" は無視されます。

3. この演算は厳密で、オーバフローしません。timedelta.seconds および
   timedelta.microseconds は 0 で、演算後には date2 + timedelta ==
   date1 となります。

4. 言い換えると、 "date1 < date2" は "date1.toordinal() <
   date2.toordinal()" と同等です。 日付の比較は、比較相手が "date" オ
   ブジェクトでない場合には、 "TypeError" を送出します。 ただし、 比較
   相手に "timetuple()" 属性がある場合は、 "NotImplemented" が代わりに
   送出されます。 このフックによって、他の種類の日付オブジェクトに、違
   う型どうしの比較処理を実装できる可能性が生まれます。 相手が
   "timetuple()" 属性を持っていない場合に "date" と違う型のオブジェク
   トと比較すると、 "==" または "!=" の比較でない限り "TypeError" が送
   出されます。 後者の場合では、それぞれ "False" および "True" が返さ
   れます。

ブール演算コンテキストでは、全ての "time" オブジェクトは真とみなされま
す。

インスタンスメソッド:

date.replace(year=self.year, month=self.month, day=self.day)

   キーワード引数で指定されたパラメータが置き換えられることを除き、同
   じ値を持つ "date" オブジェクトを返します。

   以下はプログラム例です:

      >>> from datetime import date
      >>> d = date(2002, 12, 31)
      >>> d.replace(day=26)
      datetime.date(2002, 12, 26)

date.timetuple()

   "time.localtime()" が返すような "time.struct_time" を返します。

   時分秒が 0 で、 DST フラグが -1 です。

   "d.timetuple()" は次の式と等価です:

      time.struct_time((d.year, d.month, d.day, 0, 0, 0, d.weekday(), yday, -1))

   ここで、 "yday = d.toordinal() - date(d.year, 1, 1).toordinal() +
   1" は本年の 1 月 1 日を "1" としたときの日付番号です。

date.toordinal()

   先発グレゴリオ暦における日付序数を返します。 1 年の 1 月 1 日が序数
   1 となります。任意の "date" オブジェクト *d* について、
   "date.fromordinal(d.toordinal()) == d" となります。

date.weekday()

   月曜日を 0、日曜日を 6 として、曜日を整数で返します。例えば、
   "date(2002, 12, 4).weekday() == 2" であり、水曜日を示します。
   "isoweekday()" も参照してください。

date.isoweekday()

   月曜日を 1,日曜日を 7 として、曜日を整数で返します。例えば、
   "date(2002, 12, 4).isoweekday() == 3" であり、水曜日を示します。
   "weekday()", "isocalendar()" も参照してください。

date.isocalendar()

   "year"、"week"、"weekday" の3つで構成された *named tuple* を返しま
   す。

   ISO 暦はグレゴリオ暦の変種として広く用いられています。 [3]

   ISO 年は完全な週が 52 週または 53 週あり、週は月曜から始まって日曜
   に終わります。ISO 年でのある年における最初の週は、その年の木曜日を
   含む最初の (グレゴリオ暦での) 週となります。この週は週番号 1 と呼ば
   れ、この木曜日での ISO 年はグレゴリオ暦における年と等しくなります。

   例えば、2004 年は木曜日から始まるため、ISO 年の最初の週は 2003 年
   12 月 29 日、月曜日から始まり、2004 年 1 月 4 日、日曜日に終わりま
   す

      >>> from datetime import date
      >>> date(2003, 12, 29).isocalendar()
      datetime.IsoCalendarDate(year=2004, week=1, weekday=1)
      >>> date(2004, 1, 4).isocalendar()
      datetime.IsoCalendarDate(year=2004, week=1, weekday=7)

   バージョン 3.9 で変更: 結果が タプル から *named tuple* へ変更され
   ました。

date.isoformat()

   日付を ISO 8601 書式の "YYYY-MM-DD" で表した文字列を返します:

      >>> from datetime import date
      >>> date(2002, 12, 4).isoformat()
      '2002-12-04'

   この関数は "date.fromisoformat()" の逆関数です。

date.__str__()

   "date" オブジェクト *d* において、"str(d)" は "d.isoformat()" と等
   価です。

date.ctime()

   日付を表す文字列を返します:

      >>> from datetime import date
      >>> date(2002, 12, 4).ctime()
      'Wed Dec  4 00:00:00 2002'

   "d.ctime()" は次の式と等価です:

      time.ctime(time.mktime(d.timetuple()))

   これが等価になるのは、 ("time.ctime()" に呼び出され、
   "date.ctime()" に呼び出されない) ネイティブの C 関数 "ctime()" が C
   標準に準拠しているプラットフォーム上でです。

date.strftime(format)

   明示的な書式文字列で制御された、日付を表現する文字列を返します。 時
   間、分、秒を表す書式コードは値 0 になります。 完全な書式化指定子の
   リストについては strftime() と strptime() の振る舞い を参照してくだ
   さい。

date.__format__(format)

   "date.strftime()" と等価です。 これにより、 フォーマット済み文字列
   リテラル の中や "str.format()" を使っているときに "date" オブジェク
   トの書式文字列を指定できます。 書式化コードの完全なリストについては
   strftime() と strptime() の振る舞い を参照してください。


使用例: "date"
--------------

イベントまでの日数を数える例を示します:

   >>> import time
   >>> from datetime import date
   >>> today = date.today()
   >>> today
   datetime.date(2007, 12, 5)
   >>> today == date.fromtimestamp(time.time())
   True
   >>> my_birthday = date(today.year, 6, 24)
   >>> if my_birthday < today:
   ...     my_birthday = my_birthday.replace(year=today.year + 1)
   >>> my_birthday
   datetime.date(2008, 6, 24)
   >>> time_to_birthday = abs(my_birthday - today)
   >>> time_to_birthday.days
   202

さらなる "date" を使う例:

   >>> from datetime import date
   >>> d = date.fromordinal(730920) # 730920th day after 1. 1. 0001
   >>> d
   datetime.date(2002, 3, 11)

   >>> # Methods related to formatting string output
   >>> d.isoformat()
   '2002-03-11'
   >>> d.strftime("%d/%m/%y")
   '11/03/02'
   >>> d.strftime("%A %d. %B %Y")
   'Monday 11. March 2002'
   >>> d.ctime()
   'Mon Mar 11 00:00:00 2002'
   >>> 'The {1} is {0:%d}, the {2} is {0:%B}.'.format(d, "day", "month")
   'The day is 11, the month is March.'

   >>> # Methods for to extracting 'components' under different calendars
   >>> t = d.timetuple()
   >>> for i in t:     
   ...     print(i)
   2002                # year
   3                   # month
   11                  # day
   0
   0
   0
   0                   # weekday (0 = Monday)
   70                  # 70th day in the year
   -1
   >>> ic = d.isocalendar()
   >>> for i in ic:    
   ...     print(i)
   2002                # ISO year
   11                  # ISO week number
   1                   # ISO day number ( 1 = Monday )

   >>> # A date object is immutable; all operations produce a new object
   >>> d.replace(year=2005)
   datetime.date(2005, 3, 11)


"datetime" オブジェクト
=======================

"datetime" オブジェクトは "date" オブジェクトおよび "time" オブジェク
トの全ての情報が入っている単一のオブジェクトです。

"date" オブジェクトと同様に、 "datetime" は現在のグレゴリオ暦が両方向
に延長されているものと仮定します。また、 "time" オブジェクトと同様に、
"datetime" は毎日が厳密に 3600*24 秒であると仮定します。

以下にコンストラクタを示します:

class datetime.datetime(year, month, day, hour=0, minute=0, second=0, microsecond=0, tzinfo=None, *, fold=0)

   *year*, *month*, *day* 引数は必須です。 *tzinfo* は "None" または
   "tzinfo" サブクラスのインスタンスです。 残りの引数は次の範囲の整数
   でなければなりません:

   * "MINYEAR <= year <= MAXYEAR",

   * "1 <= month <= 12",

   * "1 <= day <= 指定された月と年における日数",

   * "0 <= hour < 24",

   * "0 <= minute < 60",

   * "0 <= second < 60",

   * "0 <= microsecond < 1000000",

   * "fold in [0, 1]".

   範囲を超えた引数を与えた場合、 "ValueError" が送出されます。

   バージョン 3.6 で追加: "fold" 引数が追加されました。

他のコンストラクタ、および全てのクラスメソッドを以下に示します:

classmethod datetime.today()

   "tzinfo" を "None" にして、現在のローカルな日時を返します。

   次と等価です:

      datetime.fromtimestamp(time.time())

   "now()", "fromtimestamp()" も参照してください。

   このメソッドの機能は "now()" と等価ですが、 "tz" 引数はありません。

classmethod datetime.now(tz=None)

   現在のローカルな日時を返します。

   オプションの引数 *tz* が "None" であるか指定されていない場合、この
   メソッドは "today()" と同様ですが、可能ならば "time.time()" タイム
   スタンプを通じて得ることができる、より高い精度で時刻を提供します (
   例えば、プラットフォームが C  関数 "gettimeofday()" をサポートする
   場合には可能なことがあります)。

   *tz* が "None" でない場合、 *tz* は "tzinfo" のサブクラスのインスタ
   ンスでなければならず、現在の日付および時刻は *tz* のタイムゾーンに
   変換されます。

   "today()" および "utcnow()" よりもこの関数を使う方が好ましいです。

classmethod datetime.utcnow()

   "tzinfo" が "None" である現在の UTC の日付および時刻を返します。

   このメソッドは "now()" と似ていますが、 naive な "datetime" オブジ
   ェクトとして現在の UTC 日付および時刻を返します。 aware な現在の
   UTC datetime は "datetime.now(timezone.utc)" を呼び出すことで取得で
   きます。 "now()" も参照してください。

   警告:

     naive な "datetime" オブジェクトは多くの "datetime" メソッドでロ
     ーカルな時間として扱われるため、 aware な datetime を使って UTC
     の時刻を表すのが好ましいです。 そのため、 UTC での現在の時刻を表
     すオブジェクトの作成では "datetime.now(timezone.utc)" を呼び出す
     方法が推奨されます。

classmethod datetime.fromtimestamp(timestamp, tz=None)

   "time.time()" が返すような、 POSIX タイムスタンプに対応するローカル
   な日付と時刻を返します。オプションの引数 *tz* が "None" であるか、
   指定されていない場合、タイムスタンプはプラットフォームのローカルな
   日付および時刻に変換され、返される "datetime" オブジェクトは naive
   なものになります。

   *tz* が "None" でない場合、 *tz* は "tzinfo" のサブクラスのインスタ
   ンスでなければならず、タイムスタンプは *tz* のタイムゾーンに変換さ
   れます。

   タイムスタンプがプラットフォームの C 関数 "localtime()" や
   "gmtime()" でサポートされている範囲を超えた場合、 "fromtimestamp()"
   は "OverflowError" を送出することがあります。この範囲はよく 1970 年
   から 2038 年に制限されています。 また "localtime()" や "gmtime()"
   が失敗した際は "OSError" を送出します。 うるう秒がタイムスタンプの
   概念に含まれている非 POSIX システムでは、 "fromtimestamp()" はうる
   う秒を無視します。 このため、秒の異なる二つのタイムスタンプが同一の
   "datetime" オブジェクトとなることが起こり得ます。
   "utcfromtimestamp()" よりも、このメソッドの方が好ましいです。

   バージョン 3.3 で変更: timestamp がプラットフォームの C 関数
   "localtime()" もしくは "gmtime()" のサポートする値の範囲から外れて
   いた場合、 "ValueError" ではなく "OverflowError" を送出するようにな
   りました。 "localtime()" もしくは "gmtime()" の呼び出し失敗で
   "ValueError" ではなく "OSError" を送出するようになりました。

   バージョン 3.6 で変更: "fromtimestamp()" は "fold" を1にしてインス
   タンスを返します。

classmethod datetime.utcfromtimestamp(timestamp)

   POSIX タイムスタンプに対応する、"tzinfo" が "None" の UTC での
   "datetime" を返します。(返されるオブジェクトは naive です。)

   タイムスタンプがプラットフォームにおける C 関数 "localtime()" でサ
   ポートされている範囲を超えている場合には "OverflowError" を、
   "gmtime()" が失敗した場合には "OSError" を送出します。 これはたいて
   い 1970 年から 2038 年に制限されています。

   aware な "datetime" オブジェクトを得るには "fromtimestamp()" を呼ん
   でください:

      datetime.fromtimestamp(timestamp, timezone.utc)

   POSIX 互換プラットフォームでは、これは以下の表現と等価です:

      datetime(1970, 1, 1, tzinfo=timezone.utc) + timedelta(seconds=timestamp)

   後者を除き、式は常に年の全範囲 ("MINYEAR" から "MAXYEAR" を含みます
   ) をサポートします。

   警告:

     naive な "datetime" オブジェクトは多くの "datetime" メソッドでロ
     ーカルな時間として扱われるため、 aware な datetime を使って UTC
     の時刻を表すのが好ましいです。 そのため、 UTC でのある特定のタイ
     ムスタンプを表すオブジェクトの作成では
     "datetime.fromtimestamp(timestamp, tz=timezone.utc)" を呼び出す方
     法が推奨されます。

   バージョン 3.3 で変更: timestamp がプラットフォームの C 関数
   "gmtime()" のサポートする値の範囲から外れていた場合、 "ValueError"
   ではなく "OverflowError" を送出するようになりました。 "gmtime()" の
   呼び出し失敗で "ValueError" ではなく "OSError" を送出するようになり
   ました。

classmethod datetime.fromordinal(ordinal)

   1 年 1 月 1 日を序数 1 とする早期グレゴリオ暦序数に対応する
   "datetime" オブジェクトを返します。 "1 <= ordinal <=
   datetime.max.toordinal()" でなければ "ValueError" が送出されます。
   返されるオブジェクトの時間、分、秒、およびマイクロ秒はすべて 0 で、
   "tzinfo" は "None" となっています。

classmethod datetime.combine(date, time, tzinfo=self.tzinfo)

   日付部分と与えられた "date" オブジェクトとが等しく、時刻部分と与え
   られた "time" オブジェクトとが等しい、新しい "datetime" オブジェク
   トを返します。 *tzinfo* 引数が与えられた場合、その値は返り値の
   "tzinfo" 属性に設定するのに使われます。そうでない場合、 *time* 引数
   の "tzinfo" 属性が使われます。

   任意の "datetime" オブジェクト *d* で "d ==
   datetime.combine(d.date(), d.time(), d.tzinfo)" が成立します。 date
   が "datetime" オブジェクトだった場合、その "datetime" オブジェクト
   の時刻部分と "tzinfo" 属性は無視されます。

   バージョン 3.6 で変更: *tzinfo* 引数が追加されました。

classmethod datetime.fromisoformat(date_string)

   "date.isoformat()" および "datetime.isoformat()" の出力書式で、
   *date_string* に対応する "datetime" を返します。

   具体的には、この関数は次の書式の文字列をサポートしています:

      YYYY-MM-DD[*HH[:MM[:SS[.fff[fff]]]][+HH:MM[:SS[.ffffff]]]]

   ここで "*" は任意の一文字にマッチします。

   ご用心:

     このメソッドは任意の ISO 8601 文字列の構文解析をサポートしてはい
     ません - このメソッドは "datetime.isoformat()" の逆操作をするため
     だけのものです。 より高機能な ISO 8601 構文解析器である
     "dateutil.parser.isoparse" が、サードパーティーパッケージの
     dateutil から利用可能です。

   例:

      >>> from datetime import datetime
      >>> datetime.fromisoformat('2011-11-04')
      datetime.datetime(2011, 11, 4, 0, 0)
      >>> datetime.fromisoformat('2011-11-04T00:05:23')
      datetime.datetime(2011, 11, 4, 0, 5, 23)
      >>> datetime.fromisoformat('2011-11-04 00:05:23.283')
      datetime.datetime(2011, 11, 4, 0, 5, 23, 283000)
      >>> datetime.fromisoformat('2011-11-04 00:05:23.283+00:00')
      datetime.datetime(2011, 11, 4, 0, 5, 23, 283000, tzinfo=datetime.timezone.utc)
      >>> datetime.fromisoformat('2011-11-04T00:05:23+04:00')   
      datetime.datetime(2011, 11, 4, 0, 5, 23,
          tzinfo=datetime.timezone(datetime.timedelta(seconds=14400)))

   バージョン 3.7 で追加.

classmethod datetime.fromisocalendar(year, week, day)

   年月日で指定された ISO 暦の日付に対応する "datetime" を返します。
   datetime の日付でない部分は、標準のデフォルト値で埋められます。 こ
   の関数は "datetime.isocalendar()" の逆関数です。

   バージョン 3.8 で追加.

classmethod datetime.strptime(date_string, format)

   *date_string* に対応した "datetime" を返します。 *format* にしたが
   って構文解析されます。

   これは次と等価です:

      datetime(*(time.strptime(date_string, format)[0:6]))

   date_string と format が "time.strptime()" で構文解析できない場合や
   、この関数が時刻タプルを返してこない場合には "ValueError" を送出し
   ます。完全な書式化指定子のリストについては strftime() と strptime()
   の振る舞い を参照してください。

以下にクラス属性を示します:

datetime.min

   表現できる最も古い "datetime" で、 "datetime(MINYEAR, 1, 1,
   tzinfo=None)" です。

datetime.max

   表現できる最も新しい "datetime" で、 "datetime(MAXYEAR, 12, 31, 23,
   59, 59, 999999, tzinfo=None)" です。

datetime.resolution

   等しくない "datetime" オブジェクト間の最小の差で、
   "timedelta(microseconds=1)" です。

インスタンスの属性 (読み出しのみ):

datetime.year

   両端値を含む "MINYEAR" から "MAXYEAR" までの値です。

datetime.month

   両端値を含む 1 から 12 までの値です。

datetime.day

   1 から与えられた月と年における日数までの値です。

datetime.hour

   in "range(24)" を満たします。

datetime.minute

   in "range(60)" を満たします。

datetime.second

   in "range(60)" を満たします。

datetime.microsecond

   in "range(1000000)" を満たします。

datetime.tzinfo

   "datetime" コンストラクタに *tzinfo* 引数として与えられたオブジェク
   トになり、何も渡されなかった場合には "None" になります。

datetime.fold

   "[0, 1]" のどちらかです。 繰り返し期間中の実時間の曖昧さ除去に使わ
   れます。 (繰り返し期間は、夏時間の終わりに時計が巻き戻るときや、現
   在のゾーンの UTC オフセットが政治的な理由で減少するときに発生します
   。) 0 (1) という値は、同じ実時間で表現される 2 つの時刻のうちの早い
   方 (遅い方) を表します。

   バージョン 3.6 で追加.

サポートされている演算を以下に示します:

+-----------------------------------------+----------------------------------+
| 演算                                    | 結果                             |
|=========================================|==================================|
| "datetime2 = datetime1 + timedelta"     | (1)                              |
+-----------------------------------------+----------------------------------+
| "datetime2 = datetime1 - timedelta"     | (2)                              |
+-----------------------------------------+----------------------------------+
| "timedelta = datetime1 - datetime2"     | (3)                              |
+-----------------------------------------+----------------------------------+
| "datetime1 < datetime2"                 | "datetime" を "datetime" と比較  |
|                                         | します。 (4)                     |
+-----------------------------------------+----------------------------------+

1. datetime2 は datetime1 から時間 timedelta 移動したもので、
   "timedelta.days" > 0 の場合未来へ、 "timedelta.days" < 0 の場合過去
   へ移動します。 結果は入力の datetime と同じ "tzinfo" 属性を持ち、演
   算後には datetime2 - datetime1 == timedelta となります。
   datetime2.year が "MINYEAR" よりも小さいか、 "MAXYEAR" より大きい場
   合には "OverflowError" が送出されます。 入力が aware なオブジェクト
   の場合でもタイムゾーン修正は全く行われません。

2. datetime2 + timedelta == datetime1 となるような datetime2 を計算し
   ます。 ちなみに、結果は入力の datetime と同じ "tzinfo" 属性を持ち、
   入力が aware だとしてもタイムゾーン修正は全く行われません。 この操
   作は date1 + (-timedelta) と等価ではありません。 なぜならば、 date1
   - timedelta がオーバフローしない場合でも、-timedelta 単体がオーバフ
   ローする可能性があるからです。

3. "datetime" から "datetime" の減算は両方の被演算子が naive であるか
   、両方とも aware である場合にのみ定義されています。片方が aware で
   もう一方が naive の場合、 "TypeError" が送出されます。

   両方とも naive か、両方とも aware で同じ "tzinfo" 属性を持つ場合、
   "tzinfo" 属性は無視され、結果は "datetime2 + t == datetime1" である
   ような "timedelta" オブジェクト *t* となります。 この場合タイムゾー
   ン修正は全く行われません。

   両方が aware で異なる "tzinfo" 属性を持つ場合、 "a-b" は *a* および
   *b* をまず naive な UTC datetime オブジェクトに変換したかのようにし
   て行います。 演算結果は決してオーバフローを起こさないことを除き、
   "(a.replace(tzinfo=None) - a.utcoffset()) - (b.replace(tzinfo=None)
   - b.utcoffset())" と同じになります。

4. *datetime1* が時刻として *datetime2* よりも前を表す場合に、
   *datetime1* は *datetime2* よりも小さいと見なされます。

   比較の一方が naive であり、もう一方が aware の場合に、順序比較が行
   われると "TypeError" が送出されます。等価比較では、 naive インスタ
   ンスと aware インスタンスは等価になることはありません。

   比較対象が両方とも aware で、同じ "tzinfo" 属性を持つ場合、
   "tzinfo" は無視され datetime だけで比較が行われます。 比較対象が両
   方とも aware であり、異なる "tzinfo" 属性を持つ場合、まず最初に
   ("self.utcoffset()" で取得できる) それぞれの UTC オフセットを引いて
   調整します。

   バージョン 3.3 で変更: aware な "datetime" インスタンスと naive な
   "datetime" インスタンスの等価比較では "TypeError" は送出されません
   。

   注釈:

     型混合の比較がデフォルトのオブジェクトアドレス比較となってしまう
     のを抑止するために、被演算子のもう一方が "datetime" オブジェクト
     と異なる型のオブジェクトの場合には "TypeError" が送出されます。し
     かしながら、被比較演算子のもう一方が "timetuple()" 属性を持つ場合
     には "NotImplemented" が返されます。このフックにより、他種の日付
     オブジェクトに型混合比較を実装するチャンスを与えています。そうで
     ない場合, "datetime" オブジェクトと異なる型のオブジェクトが比較さ
     れると、比較演算子が "==" または "!=" でないかぎり "TypeError" が
     送出されます。後者の場合、それぞれ "False" または "True" を返しま
     す。

インスタンスメソッド:

datetime.date()

   同じ年、月、日の "date" オブジェクトを返します。

datetime.time()

   同じhour、minute、second、microsecond 及び foldを持つ "time" オブジ
   ェクトを返します。 "tzinfo" は "None" です。 "timetz()" も参照して
   ください。

   バージョン 3.6 で変更: 値 foldは返される "time" オブジェクトにコピ
   ーされます。

datetime.timetz()

   同じhour、minute、second、microsecond、fold および tzinfo 属性を持
   つ "time" オブジェクトを返します。  "time()" メソッドも参照してくだ
   さい。

   バージョン 3.6 で変更: 値 foldは返される "time" オブジェクトにコピ
   ーされます。

datetime.replace(year=self.year, month=self.month, day=self.day, hour=self.hour, minute=self.minute, second=self.second, microsecond=self.microsecond, tzinfo=self.tzinfo, *, fold=0)

   キーワード引数で指定した属性の値を除き、同じ属性をもつ datetime オ
   ブジェクトを返します。メンバに対する変換を行わずに aware な
   datetime オブジェクトから naive な datetime オブジェクトを生成する
   ために、"tzinfo=None" を指定することもできます。

   バージョン 3.6 で追加: "fold" 引数が追加されました。

datetime.astimezone(tz=None)

   *tz* を新たに "tzinfo" 属性 として持つ "datetime" オブジェクトを返
   します。 日付および時刻データを調整して、返り値が *self* と同じ UTC
   時刻を持ち、 *tz* におけるローカルな時刻を表すようにします。

   もし与えられた場合、 *tz* は "tzinfo" のサブクラスのインスタンスで
   なければならず、 インスタンスの "utcoffset()" および "dst()" メソッ
   ドは "None" を返してはなりません。もし *self* が naive ならば、おそ
   らくシステムのタイムゾーンで時間を表現します。

   引数無し (もしくは "tz=None" の形 ) で呼び出された場合、システムの
   ローカルなタイムゾーンが変更先のタイムゾーンだと仮定されます。 変換
   後の datetime インスタンスの ".tzinfo" 属性には、 OS から取得したゾ
   ーン名とオフセットを持つ "timezone" インスタンスが設定されます。

   "self.tzinfo" が *tz* の場合、 "self.astimezone(tz)" は *self* に等
   しくなります。つまり、date および time に対する調整は行われません。
   そうでない場合、結果はタイムゾーン *tz* におけるローカル時刻で、
   *self* と同じ UTC 時刻を表すようになります。これは、"astz =
   dt.astimezone(tz)" とした後、 "astz - astz.utcoffset()" は通常 "dt
   - dt.utcoffset()" と同じ date および time を持つことを示します。

   単にタイムゾーンオブジェクト *tz* を "datetime" オブジェクト *dt*
   に追加したいだけで、日付や時刻データへの調整を行わないのなら、
   "dt.replace(tzinfo=tz)" を使ってください。単に aware な "datetime"
   オブジェクト *dt* からタイムゾーンオブジェクトを除去したいだけで、
   日付や時刻データの変換を行わないのなら、"dt.replace(tzinfo=None)"
   を使ってください。

   デフォルトの "tzinfo.fromutc()" メソッドを "tzinfo" のサブクラスで
   上書きして, "astimezone()" が返す結果に影響を及ぼすことができます。
   エラーの場合を無視すると、 "astimezone()" は以下のように動作します:

      def astimezone(self, tz):
          if self.tzinfo is tz:
              return self
          # Convert self to UTC, and attach the new time zone object.
          utc = (self - self.utcoffset()).replace(tzinfo=tz)
          # Convert from UTC to tz's local time.
          return tz.fromutc(utc)

   バージョン 3.3 で変更: *tz* が省略可能になりました。

   バージョン 3.6 で変更: "datetime.datetime.astimezone()" メソッドを
   naive なインスタンスに対して呼び出せるようになりました。これは、シ
   ステムのローカルな時間を表現していると想定されます。

datetime.utcoffset()

   "tzinfo" が "None" の場合、 "None" を返し、そうでない場合には
   "self.tzinfo.utcoffset(self)" を返します。 後者の式が "None" あるい
   は 1 日以下の大きさを持つ "timedelta" オブジェクトのいずれかを返さ
   ない場合には例外を送出します。

   バージョン 3.7 で変更: UTC オフセットが分単位でなければならない制限
   が無くなりました。

datetime.dst()

   "tzinfo" が "None" の場合 "None" を返し、そうでない場合には
   "self.tzinfo.dst(self)" を返します。 後者の式が "None" もしくは、1
   日未満の大きさを持つ "timedelta" オブジェクトのいずれかを返さない場
   合には例外を送出します。

   バージョン 3.7 で変更: DST オフセットが分単位でなければならない制限
   が無くなりました。

datetime.tzname()

   "tzinfo" が "None" の場合 "None" を返し、そうでない場合には
   "self.tzinfo.tzname(self)" を返します。 後者の式が "None" か文字列
   オブジェクトのいずれかを返さない場合には例外を送出します。

datetime.timetuple()

   "time.localtime()" が返すような "time.struct_time" を返します。

   "d.timetuple()" は次の式と等価です:

      time.struct_time((d.year, d.month, d.day,
                        d.hour, d.minute, d.second,
                        d.weekday(), yday, dst))

   ここで "yday = d.toordinal() - date(d.year, 1, 1).toordinal() + 1"
   はその年の1月1日を "1" としたときのその日の位置です。 返されるタプ
   ルの "tm_isdst" フラグは "dst()" メソッドに従って設定されます:
   "tzinfo" が "None" か "dst()" が "None" を返す場合、 "tm_isdst" は
   "-1" に設定されます; そうでない場合、 "dst()" がゼロでない値を返す
   と "tm_isdst" は "1" となります; それ以外の場合には "tm_isdst" は
   "0" に設定されます。

datetime.utctimetuple()

   "datetime" インスタンス *d* が naive の場合、このメソッドは
   "d.timetuple()" と同じであり、 "d.dst()" の返す内容にかかわらず
   "tm_isdst" が 0 に強制される点だけが異なります。 DST が UTC 時刻に
   影響を及ぼすことは決してありません。

   *d* が aware だった場合、 *d* は "d.utcoffset()" を引いて UTC 時刻
   に正規化され、その時刻が "time.struct_time" として返されます。
   "tm_isdst" は 0 に強制されます。 *d*.year が "MINYEAR" もしくは
   "MAXYEAR" であり、 UTC 時刻への調整により適切な年の範囲を越えた場合
   、 "OverflowError" が送出される可能性があることに注意してください。

   警告:

     naive な "datetime" オブジェクトは多くの "datetime" メソッドでロ
     ーカルな時間として扱われるため、 aware な datetime を使って UTC
     の時刻を表すのが好ましいです。結果として、 "utcfromtimetuple" は
     誤解を招きやすい返り値を返すかもしれません。 UTC を表す naive な
     "datetime" があった場合、 "datetime.timetuple()" が使えるところで
     は "datetime.replace(tzinfo=timezone.utc)" で aware にします。

datetime.toordinal()

   先発グレゴリオ暦における日付序数を返します。
   "self.date().toordinal()" と同じです。

datetime.timestamp()

   "datetime" インスタンスに対応する POSIX タイムスタンプを返します。
   返り値は "time.time()" で返される値に近い "float" です。

   このメソッドでは naive な "datetime" インスタンスはローカル時刻とし
   、プラットフォームの C 関数 "mktime()" に頼って変換を行います。
   "datetime" は多くのプラットフォームの "mktime()" より広い範囲の値を
   サポートしているので、遥か過去の時刻や遥か未来の時刻に対し、このメ
   ソッドは "OverflowError" を送出するかもしれません。

   aware な "datetime" インスタンスに対しては以下のように返り値が計算
   されます:

      (dt - datetime(1970, 1, 1, tzinfo=timezone.utc)).total_seconds()

   バージョン 3.3 で追加.

   バージョン 3.6 で変更: The "timestamp()" method uses the "fold"
   attribute to disambiguate the times during a repeated interval.

   注釈:

     UTC 時刻を表す naive な "datetime" インスタンスから直接 POSIX タ
     イムスタンプを取得するメソッドはありません。 アプリケーションがそ
     の変換を使っており、システムのタイムゾーンが UTC に設定されていな
     かった場合、 "tzinfo=timezone.utc" を引数に与えることで POSIX タ
     イムスタンプを取得できます:

        timestamp = dt.replace(tzinfo=timezone.utc).timestamp()

     もしくは直接タイムスタンプを計算することもできます:

        timestamp = (dt - datetime(1970, 1, 1)) / timedelta(seconds=1)

datetime.weekday()

   月曜日を 0、日曜日を 6 として、曜日を整数で返します。
   "self.date().weekday()" と同じです。 "isoweekday()" も参照してくだ
   さい。

datetime.isoweekday()

   月曜日を 1、日曜日を 7 として、曜日を整数で返します。
   "self.date().isoweekday()" と等価です。 "weekday()" 、
   "isocalendar()" も参照してください。

datetime.isocalendar()

   "year"、"week"、"weekday" の3つで構成された *named tuple* を返しま
   す。 "self.date().isocalendar()" と等価です。

datetime.isoformat(sep='T', timespec='auto')

   日時を ISO 8601 書式で表した文字列で返します:

   * "microsecond" が 0 でない場合は "YYYY-MM-DDTHH:MM:SS.ffffff"

   * "microsecond" が 0 の場合は "YYYY-MM-DDTHH:MM:SS"

   "utcoffset()" が "None" を返さない場合は、文字列の後ろに UTC オフセ
   ットが追記されます:

   * "microsecond" が 0 でない場合は "YYYY-MM-
     DDTHH:MM:SS.ffffff+HH:MM[:SS[.ffffff]]"

   * "microsecond" が 0 の場合は "YYYY-MM-
     DDTHH:MM:SS+HH:MM[:SS[.ffffff]]"

   例:

      >>> from datetime import datetime, timezone
      >>> datetime(2019, 5, 18, 15, 17, 8, 132263).isoformat()
      '2019-05-18T15:17:08.132263'
      >>> datetime(2019, 5, 18, 15, 17, tzinfo=timezone.utc).isoformat()
      '2019-05-18T15:17:00+00:00'

   オプションの引数 *sep* (デフォルトでは "'T'" です)  は 1 文字のセパ
   レータで、結果の文字列の日付と時刻の間に置かれます。例えば:

      >>> from datetime import tzinfo, timedelta, datetime
      >>> class TZ(tzinfo):
      ...     """A time zone with an arbitrary, constant -06:39 offset."""
      ...     def utcoffset(self, dt):
      ...         return timedelta(hours=-6, minutes=-39)
      ...
      >>> datetime(2002, 12, 25, tzinfo=TZ()).isoformat(' ')
      '2002-12-25 00:00:00-06:39'
      >>> datetime(2009, 11, 27, microsecond=100, tzinfo=TZ()).isoformat()
      '2009-11-27T00:00:00.000100-06:39'

   オプション引数 *timespec* は、含める追加の時間の要素の数を指定しま
   す(デフォルトでは "'auto'" です)。以下の内一つを指定してください。

   * "'auto'": "microsecond" が0である場合 "'seconds'" と等しく、そう
     でない場合は "'microseconds'" と等しくなります。

   * "'hours'":  "hour" を2桁の "HH" 書式で含めます。

   * "'minutes'": "hour" および "minute" を "HH:MM" の書式で含めます。

   * "'seconds'": "hour" 、 "minute" 、 "second"  を "HH:MM:SS" の書式
     で含めます。

   * "'milliseconds'": 全ての時刻を含みますが、小数第二位をミリ秒に切
     り捨てます。 "HH:MM:SS.sss" の書式で表現します。

   * "'microseconds'": 全ての時刻を "HH:MM:SS.mmmmmm" の書式で含めます
     。

   注釈:

     除外された要素は丸め込みではなく、切り捨てされます。

   不正な *timespec* 引数には "ValueError" があげられます:

      >>> from datetime import datetime
      >>> datetime.now().isoformat(timespec='minutes')   
      '2002-12-25T00:00'
      >>> dt = datetime(2015, 1, 1, 12, 30, 59, 0)
      >>> dt.isoformat(timespec='microseconds')
      '2015-01-01T12:30:59.000000'

   バージョン 3.6 で追加: *timespec* 引数が追加されました。

datetime.__str__()

   "datetime" オブジェクト *d* において、 "str(d)" は "d.isoformat('
   ')" と等価です。

datetime.ctime()

   日付および時刻を表す文字列を返します:

      >>> from datetime import datetime
      >>> datetime(2002, 12, 4, 20, 30, 40).ctime()
      'Wed Dec  4 20:30:40 2002'

   出力文字列は入力が aware であれ naive であれ、タイムゾーン情報を含
   み *ません*。

   "d.ctime()" は次の式と等価です:

      time.ctime(time.mktime(d.timetuple()))

   これが等価になるのは、 ("time.ctime()" に呼び出され、
   "datetime.ctime()" に呼び出されない) ネイティブの C 関数 "ctime()"
   が C 標準に準拠しているプラットフォーム上でです。

datetime.strftime(format)

   明示的な書式文字列で制御された、日付および時刻を表現する文字列を返
   します。完全な書式化指定子のリストについては strftime() と
   strptime() の振る舞い を参照してください。

datetime.__format__(format)

   "datetime.strftime()" と等価です。 これにより、 フォーマット済み文
   字列リテラル の中や "str.format()" を使っているときに "datetime" オ
   ブジェクトの書式文字列を指定できます。 書式化指定子の完全なリストに
   ついては strftime() と strptime() の振る舞い を参照してください。


使用例: "datetime"
------------------

"datetime" オブジェクトを使う例:

   >>> from datetime import datetime, date, time, timezone

   >>> # Using datetime.combine()
   >>> d = date(2005, 7, 14)
   >>> t = time(12, 30)
   >>> datetime.combine(d, t)
   datetime.datetime(2005, 7, 14, 12, 30)

   >>> # Using datetime.now()
   >>> datetime.now()   
   datetime.datetime(2007, 12, 6, 16, 29, 43, 79043)   # GMT +1
   >>> datetime.now(timezone.utc)   
   datetime.datetime(2007, 12, 6, 15, 29, 43, 79060, tzinfo=datetime.timezone.utc)

   >>> # Using datetime.strptime()
   >>> dt = datetime.strptime("21/11/06 16:30", "%d/%m/%y %H:%M")
   >>> dt
   datetime.datetime(2006, 11, 21, 16, 30)

   >>> # Using datetime.timetuple() to get tuple of all attributes
   >>> tt = dt.timetuple()
   >>> for it in tt:   
   ...     print(it)
   ...
   2006    # year
   11      # month
   21      # day
   16      # hour
   30      # minute
   0       # second
   1       # weekday (0 = Monday)
   325     # number of days since 1st January
   -1      # dst - method tzinfo.dst() returned None

   >>> # Date in ISO format
   >>> ic = dt.isocalendar()
   >>> for it in ic:   
   ...     print(it)
   ...
   2006    # ISO year
   47      # ISO week
   2       # ISO weekday

   >>> # Formatting a datetime
   >>> dt.strftime("%A, %d. %B %Y %I:%M%p")
   'Tuesday, 21. November 2006 04:30PM'
   >>> 'The {1} is {0:%d}, the {2} is {0:%B}, the {3} is {0:%I:%M%p}.'.format(dt, "day", "month", "time")
   'The day is 21, the month is November, the time is 04:30PM.'

下にある例では、1945年までは +4 UTC 、それ以降は +4:30 UTC を使用して
いるアフガニスタンのカブールのタイムゾーン情報を表現する "tzinfo" のサ
ブクラスを定義しています:

   from datetime import timedelta, datetime, tzinfo, timezone

   class KabulTz(tzinfo):
       # Kabul used +4 until 1945, when they moved to +4:30
       UTC_MOVE_DATE = datetime(1944, 12, 31, 20, tzinfo=timezone.utc)

       def utcoffset(self, dt):
           if dt.year < 1945:
               return timedelta(hours=4)
           elif (1945, 1, 1, 0, 0) <= dt.timetuple()[:5] < (1945, 1, 1, 0, 30):
               # An ambiguous ("imaginary") half-hour range representing
               # a 'fold' in time due to the shift from +4 to +4:30.
               # If dt falls in the imaginary range, use fold to decide how
               # to resolve. See PEP495.
               return timedelta(hours=4, minutes=(30 if dt.fold else 0))
           else:
               return timedelta(hours=4, minutes=30)

       def fromutc(self, dt):
           # Follow same validations as in datetime.tzinfo
           if not isinstance(dt, datetime):
               raise TypeError("fromutc() requires a datetime argument")
           if dt.tzinfo is not self:
               raise ValueError("dt.tzinfo is not self")

           # A custom implementation is required for fromutc as
           # the input to this function is a datetime with utc values
           # but with a tzinfo set to self.
           # See datetime.astimezone or fromtimestamp.
           if dt.replace(tzinfo=timezone.utc) >= self.UTC_MOVE_DATE:
               return dt + timedelta(hours=4, minutes=30)
           else:
               return dt + timedelta(hours=4)

       def dst(self, dt):
           # Kabul does not observe daylight saving time.
           return timedelta(0)

       def tzname(self, dt):
           if dt >= self.UTC_MOVE_DATE:
               return "+04:30"
           return "+04"

上に出てきた "KabulTz" の使い方:

   >>> tz1 = KabulTz()

   >>> # Datetime before the change
   >>> dt1 = datetime(1900, 11, 21, 16, 30, tzinfo=tz1)
   >>> print(dt1.utcoffset())
   4:00:00

   >>> # Datetime after the change
   >>> dt2 = datetime(2006, 6, 14, 13, 0, tzinfo=tz1)
   >>> print(dt2.utcoffset())
   4:30:00

   >>> # Convert datetime to another time zone
   >>> dt3 = dt2.astimezone(timezone.utc)
   >>> dt3
   datetime.datetime(2006, 6, 14, 8, 30, tzinfo=datetime.timezone.utc)
   >>> dt2
   datetime.datetime(2006, 6, 14, 13, 0, tzinfo=KabulTz())
   >>> dt2 == dt3
   True


"time" オブジェクト
===================

"time" オブジェクトは (ローカルの) 日中時刻を表現します。 この時刻表現
は特定の日の影響を受けず、 "tzinfo" オブジェクトを介した修正の対象とな
ります。

class datetime.time(hour=0, minute=0, second=0, microsecond=0, tzinfo=None, *, fold=0)

   全ての引数はオプションです。 *tzinfo* は "None" または "tzinfo" ク
   ラスのサブクラスのインスタンスにすることができます。残りの引数は整
   数で、以下のような範囲に入らなければなりません:

   * "0 <= hour < 24",

   * "0 <= minute < 60",

   * "0 <= second < 60",

   * "0 <= microsecond < 1000000",

   * "fold in [0, 1]".

   引数がこれらの範囲外にある場合、 "ValueError" が送出されます。
   *tzinfo* のデフォルト値が "None" である以外のデフォルト値は "0" で
   す。

以下にクラス属性を示します:

time.min

   表現できる最も古い "time" で、 "time(0, 0, 0, 0)" です。

time.max

   表現できる最も新しい "time" で、 "time(23, 59, 59, 999999)" です。

time.resolution

   等しくない "time" オブジェクト間の最小の差で、
   "timedelta(microseconds=1)" ですが, "time" オブジェクト間の四則演算
   はサポートされていないので注意してください。

インスタンスの属性 (読み出しのみ):

time.hour

   in "range(24)" を満たします。

time.minute

   in "range(60)" を満たします。

time.second

   in "range(60)" を満たします。

time.microsecond

   in "range(1000000)" を満たします。

time.tzinfo

   "time" コンストラクタに *tzinfo* 引数として与えられたオブジェクトに
   なり、何も渡されなかった場合には "None" になります。

time.fold

   "[0, 1]" のどちらかです。 繰り返し期間中の実時間の曖昧さ除去に使わ
   れます。 (繰り返し期間は、夏時間の終わりに時計が巻き戻るときや、現
   在のゾーンの UTC オフセットが政治的な理由で減少するときに発生します
   。) 0 (1) という値は、同じ実時間で表現される 2 つの時刻のうちの早い
   方 (遅い方) を表します。

   バージョン 3.6 で追加.

"time" オブジェクトは "time" どうしの比較をサポートしていて、 *a* が
*b* より前の時刻だった場合 *a* が *b* より小さいとされます。 比較対象
の片方が naive であり、もう片方が aware の場合に、順序比較が行われると
"TypeError" が送出されます。 等価比較では、 naive インスタンスと aware
インスタンスは等価になることはありません。

比較対象が両方とも aware であり、同じ "tzinfo" 属性を持つ場合、
"tzinfo" は無視され datetime だけで比較が行われます。 比較対象が両方と
も aware であり、異なる "tzinfo" 属性を持つ場合、まず最初に
("self.utcoffset()" で取得できる) それぞれの UTC オフセットを引いて調
整します。 異なる型どうしの比較がデフォルトのオブジェクトアドレス比較
となってしまうのを防ぐために、 "time" オブジェクトを異なる型のオブジェ
クトと比較すると、比較演算子が "==" または "!=" でないかぎり
"TypeError" が送出されます。 比較演算子が "==" または "!=" である場合
、それぞれ "False" または "True" を返します。

バージョン 3.3 で変更: aware な "datetime" インスタンスと naive な
"time" インスタンスの等価比較では "TypeError" は送出されません。

ブール値の文脈では、 "time" オブジェクトは常に真とみなされます。

バージョン 3.5 で変更: Python 3.5 以前は、 "time" オブジェクトは UTC
で深夜を表すときに偽とみなされていました。 この挙動は分かりにくく、エ
ラーの元となると考えられ、Python 3.5 で削除されました。 全詳細について
は bpo-13936 を参照してください。

その他のコンストラクタ:

classmethod time.fromisoformat(time_string)

   "time.isoformat()" の出力書式のうちの1つの書式で、 *time_string* に
   対応する "time" を返します。 具体的には、この関数は次の書式の文字列
   をサポートしています:

      HH[:MM[:SS[.fff[fff]]]][+HH:MM[:SS[.ffffff]]]

   ご用心:

     この関数は、任意の ISO 8601 文字列の構文解析をサポートしているわ
     けでは *ありません* これは "time.isoformat()" の逆演算を意図して
     実装されています。

   例:

      >>> from datetime import time
      >>> time.fromisoformat('04:23:01')
      datetime.time(4, 23, 1)
      >>> time.fromisoformat('04:23:01.000384')
      datetime.time(4, 23, 1, 384)
      >>> time.fromisoformat('04:23:01+04:00')
      datetime.time(4, 23, 1, tzinfo=datetime.timezone(datetime.timedelta(seconds=14400)))

   バージョン 3.7 で追加.

インスタンスメソッド:

time.replace(hour=self.hour, minute=self.minute, second=self.second, microsecond=self.microsecond, tzinfo=self.tzinfo, *, fold=0)

   キーワード引数で指定したメンバの値を除き、同じ値をもつ "time" オブ
   ジェクトを返します。データに対する変換を行わずに aware な "time" オ
   ブジェクトから  naive な "time" オブジェクトを生成するために、
   "tzinfo=None" を指定することもできます。

   バージョン 3.6 で追加: "fold" 引数が追加されました。

time.isoformat(timespec='auto')

   時刻を ISO 8601 書式で表した次の文字列のうち1つを返します:

   * "microsecond" が 0 でない場合は "HH:MM:SS.ffffff"

   * "microsecond" が 0 の場合は "HH:MM:SS"

   * "utcoffset()" が "None" を返さない場合、
     "HH:MM:SS.ffffff+HH:MM[:SS[.ffffff]]"

   * "microsecond" が 0 で "utcoffset()" が "None" を返さない場合、
     "HH:MM:SS+HH:MM[:SS[.ffffff]]"

   オプション引数 *timespec* は、含める追加の時間の要素の数を指定しま
   す(デフォルトでは "'auto'" です)。以下の内一つを指定してください。

   * "'auto'": "microsecond" が0である場合 "'seconds'" と等しく、そう
     でない場合は "'microseconds'" と等しくなります。

   * "'hours'":  "hour" を2桁の "HH" 書式で含めます。

   * "'minutes'": "hour" および "minute" を "HH:MM" の書式で含めます。

   * "'seconds'": "hour" 、 "minute" 、 "second"  を "HH:MM:SS" の書式
     で含めます。

   * "'milliseconds'": 全ての時刻を含みますが、小数第二位をミリ秒に切
     り捨てます。 "HH:MM:SS.sss" の書式で表現します。

   * "'microseconds'": 全ての時刻を "HH:MM:SS.mmmmmm" の書式で含めます
     。

   注釈:

     除外された要素は丸め込みではなく、切り捨てされます。

   不正な *timespec* 引数には "ValueError" があげられます。

   以下はプログラム例です:

      >>> from datetime import time
      >>> time(hour=12, minute=34, second=56, microsecond=123456).isoformat(timespec='minutes')
      '12:34'
      >>> dt = time(hour=12, minute=34, second=56, microsecond=0)
      >>> dt.isoformat(timespec='microseconds')
      '12:34:56.000000'
      >>> dt.isoformat(timespec='auto')
      '12:34:56'

   バージョン 3.6 で追加: *timespec* 引数が追加されました。

time.__str__()

   "time" オブジェクト *t* において、"str(t)" は "t.isoformat()" と等
   価です。

time.strftime(format)

   明示的な書式文字列で制御された、時刻を表現する文字列を返します。完
   全な書式化指定子のリストについては strftime() と strptime() の振る
   舞い を参照してください。

time.__format__(format)

   "time.strftime()" と等価です。 これにより、 フォーマット済み文字列
   リテラル の中や "str.format()" を使っているときに "time" オブジェク
   トの書式文字列を指定できます。 書式化指定子の完全なリストについては
   strftime() と strptime() の振る舞い を参照してください。

time.utcoffset()

   "tzinfo" が "None" の場合、 "None" を返し、そうでない場合には
   "self.tzinfo.utcoffset(None)" を返します。 後者の式が "None" あるい
   は 1 日以下の大きさを持つ "timedelta" オブジェクトのいずれかを返さ
   ない場合には例外を送出します。

   バージョン 3.7 で変更: UTC オフセットが分単位でなければならない制限
   が無くなりました。

time.dst()

   "tzinfo" が "None" の場合 "None" を返し、そうでない場合には
   "self.tzinfo.dst(None)" を返します。 後者の式が "None" もしくは、1
   日未満の大きさを持つ "timedelta" オブジェクトのいずれかを返さない場
   合には例外を送出します。

   バージョン 3.7 で変更: DST オフセットが分単位でなければならない制限
   が無くなりました。

time.tzname()

   "tzinfo" が "None" の場合 "None" を返し、そうでない場合には
   "self.tzinfo.tzname(None)" を返します。 後者の式が "None" か文字列
   オブジェクトのいずれかを返さない場合には例外を送出します。


使用例: "time"
--------------

"time" オブジェクトを使う例:

   >>> from datetime import time, tzinfo, timedelta
   >>> class TZ1(tzinfo):
   ...     def utcoffset(self, dt):
   ...         return timedelta(hours=1)
   ...     def dst(self, dt):
   ...         return timedelta(0)
   ...     def tzname(self,dt):
   ...         return "+01:00"
   ...     def  __repr__(self):
   ...         return f"{self.__class__.__name__}()"
   ...
   >>> t = time(12, 10, 30, tzinfo=TZ1())
   >>> t
   datetime.time(12, 10, 30, tzinfo=TZ1())
   >>> t.isoformat()
   '12:10:30+01:00'
   >>> t.dst()
   datetime.timedelta(0)
   >>> t.tzname()
   '+01:00'
   >>> t.strftime("%H:%M:%S %Z")
   '12:10:30 +01:00'
   >>> 'The {} is {:%H:%M}.'.format("time", t)
   'The time is 12:10.'


"tzinfo" オブジェクト
=====================

class datetime.tzinfo

   このクラスは抽象基底クラスで、直接インスタンス化すべきでないことを
   意味します。 "tzinfo" のサブクラスを定義し、ある特定のタイムゾーン
   に関する情報を保持するようにしてください。

   "tzinfo" (の具体的なサブクラス) のインスタンスは "datetime" および
   "time" オブジェクトのコンストラクタに渡すことができます。後者のオブ
   ジェクトでは、データ属性をローカル時刻におけるものとして見ており、
   "tzinfo" オブジェクトはローカル時刻の UTC からのオフセット、タイム
   ゾーンの名前、 DST オフセットを、渡された日付および時刻オブジェクト
   からの相対で示すためのメソッドを提供します。

   具象サブクラスを作成し、(少なくとも) 使いたい "datetime" のメソッド
   が必要とする "tzinfo" のメソッドを実装する必要があります。
   "datetime" モジュールは "tzinfo" のシンプルな具象サブクラス
   "timezone" を提供します。 これは UTC そのものか北アメリカの EST と
   EDT のような UTC からの固定されたオフセットを持つタイムゾーンを表せ
   ます。

   pickle 化についての特殊な要求事項: "tzinfo" のサブクラスは引数なし
   で呼び出すことのできる "__init__()" メソッドを持たなければなりませ
   ん。そうでなければ、 pickle 化することはできますがおそらく unpickle
   化することはできないでしょう。これは技術的な側面からの要求であり、
   将来緩和されるかもしれません。

   "tzinfo" の具体的なサブクラスでは、以下のメソッドを実装する必要があ
   ります。厳密にどのメソッドが必要なのかは、 aware な "datetime" オブ
   ジェクトがこのサブクラスのインスタンスをどのように使うかに依存しま
   す。不確かならば、単に全てを実装してください。

tzinfo.utcoffset(dt)

   ローカル時間の UTC からのオフセットを、 UTC から東向きを正とした分
   で返します。ローカル時間が UTC の西側にある場合、この値は負になりま
   す。

   このメソッドは UTC からのオフセットの *総計* を表しています。例えば
   、 "tzinfo" オブジェクトがタイムゾーンと DST 修正の両方を表現する場
   合、 "utcoffset()" はそれらの合計を返さなければなりません。 UTC オ
   フセットが未知である場合、 "None" を返します。 そうでない場合には、
   返される値は "-timedelta(hours=24)" から "timedelta(hours=24)" まで
   の "timedelta" 境界を含まないオブジェクトでなければなりません (オフ
   セットの大きさは 1 日より短くなければなりません)。 ほとんどの
   "utcoffset()" 実装は、おそらく以下の二つのうちの一つに似たものにな
   るでしょう:

      return CONSTANT                 # fixed-offset class
      return CONSTANT + self.dst(dt)  # daylight-aware class

   "utcoffset()" が "None" を返さない場合、 "dst()" も "None" を返して
   はなりません。

   "utcoffset()" のデフォルトの実装は "NotImplementedError" を送出しま
   す。

   バージョン 3.7 で変更: UTC オフセットが分単位でなければならない制限
   が無くなりました。

tzinfo.dst(dt)

   夏時間 (DST) 修正を、 UTC から東向きを正とした分で返します。 DST 情
   報が未知の場合、 "None" が返されます。

   DST が有効でない場合には "timedelta(0)" を返します。 DST が有効の場
   合、オフセットは "timedelta" オブジェクトで返します (詳細は
   "utcoffset()" を参照してください)。 DST オフセットが利用可能な場合
   、この値は "utcoffset()" が返す UTC からのオフセットには既に加算さ
   れているため、 DST を個別に取得する必要がない限り "dst()" を使って
   問い合わせる必要はないので注意してください。 例えば、
   "datetime.timetuple()" は "tzinfo" 属性の "dst()" メソッドを呼んで
   "tm_isdst" フラグがセットされているかどうか判断し、
   "tzinfo.fromutc()" は "dst()" タイムゾーンを移動する際に DST による
   変更があるかどうかを調べます。

   標準および夏時間の両方をモデル化している "tzinfo" サブクラスのイン
   スタンス *tz* は以下の式:

   "tz.utcoffset(dt) - tz.dst(dt)"

   が、 "dt.tzinfo == tz" 全ての "datetime" オブジェクト *dt* について
   常に同じ結果を返さなければならないという点で、一貫性を持っていなけ
   ればなりません。正常に実装された "tzinfo" のサブクラスでは、この式
   はタイムゾーンにおける "標準オフセット (standard offset)" を表し、
   特定の日や時刻の事情ではなく地理的な位置にのみ依存していなくてはな
   りません。 "datetime.astimezone()" の実装はこの事実に依存しています
   が、違反を検出することができません; 正しく実装するのはプログラマの
   責任です。 "tzinfo" のサブクラスでこれを保証することができない場合
   、 "tzinfo.fromutc()" の実装をオーバライドして、 "astimezone()" に
   関わらず正しく動作するようにしてもかまいません。

   ほとんどの "dst()" 実装は、おそらく以下の二つのうちの一つに似たもの
   になるでしょう:

      def dst(self, dt):
          # a fixed-offset class:  doesn't account for DST
          return timedelta(0)

   もしくは:

      def dst(self, dt):
          # Code to set dston and dstoff to the time zone's DST
          # transition times based on the input dt.year, and expressed
          # in standard local time.

          if dston <= dt.replace(tzinfo=None) < dstoff:
              return timedelta(hours=1)
          else:
              return timedelta(0)

   デフォルトの "dst()" 実装は "NotImplementedError" を送出します。

   バージョン 3.7 で変更: DST オフセットが分単位でなければならない制限
   が無くなりました。

tzinfo.tzname(dt)

   "datetime" オブジェクト *dt* に対応するタイムゾーン名を文字列で返し
   ます。 "datetime" モジュールでは文字列名について何も定義しておらず
   、特に何かを意味するといった要求仕様もまったくありません。例えば、
   "GMT", "UTC", "-500", "-5:00", "EDT", "US/Eastern", "America/New
   York" は全て有効な応答となります。文字列名が未知の場合には "None"
   を返してください。 "tzinfo" のサブクラスでは、特に, "tzinfo" クラス
   が夏時間について記述している場合のように、渡された *dt* の特定の値
   によって異なった名前を返したい場合があるため、文字列値ではなくメソ
   ッドとなっていることに注意してください。

   デフォルトの "tzname()" 実装は "NotImplementedError" を送出します。

以下のメソッドは "datetime" や "time" オブジェクトにおいて、同名のメソ
ッドが呼び出された際に応じて呼び出されます。 "datetime" オブジェクトは
自身を引数としてメソッドに渡し、 "time" オブジェクトは引数として
"None" をメソッドに渡します。従って、 "tzinfo" のサブクラスにおけるメ
ソッドは引数 *dt* が "None" の場合と、 "datetime" の場合を受理するよう
に用意しなければなりません。

"None" が渡された場合、最良の応答方法を決めるのはクラス設計者次第です
。例えば、このクラスが "tzinfo" プロトコルと関係をもたないということを
表明させたければ、 "None" が適切です。標準時のオフセットを見つける他の
手段がない場合には、標準 UTC オフセットを返すために "utcoffset(None)"
を使うともっと便利かもしれません。

"datetime" オブジェクトが "datetime()" メソッドの応答として返された場
合、 "dt.tzinfo" は *self* と同じオブジェクトになります。ユーザが直接
"tzinfo" メソッドを呼び出さないかぎり、 "tzinfo" メソッドは
"dt.tzinfo" と *self* が同じであることに依存します。その結果 "tzinfo"
メソッドは *dt* がローカル時間であると解釈するので、他のタイムゾーンで
のオブジェクトの振る舞いについて心配する必要がありません。

サブクラスでオーバーライドすると良い、もう 1 つの "tzinfo" のメソッド
があります:

tzinfo.fromutc(dt)

   デフォルトの "datetime.astimezone()" 実装で呼び出されます。
   "datetime.astimezone()" から呼ばれた場合、 "dt.tzinfo" は *self* で
   あり、 *dt* の日付および時刻データは UTC 時刻を表しているものとして
   見えます。 "fromutc()" の目的は、 *self* のローカル時刻に等しい
   "datetime" オブジェクトを返すことにより日付と時刻データメンバを修正
   することにあります。

   ほとんどの "tzinfo" サブクラスではデフォルトの "fromutc()" 実装を問
   題なく継承できます。デフォルトの実装は、固定オフセットのタイムゾー
   ンや、標準時と夏時間の両方について記述しているタイムゾーン、そして
   DST 移行時刻が年によって異なる場合でさえ、扱えるくらい強力なもので
   す。デフォルトの "fromutc()" 実装が全ての場合に対して正しく扱うこと
   ができないような例は、標準時の (UTCからの) オフセットが引数として渡
   された特定の日や時刻に依存するもので、これは政治的な理由によって起
   きることがあります。デフォルトの "astimezone()" や "fromutc()" の実
   装は、結果が標準時オフセットの変化にまたがる何時間かの中にある場合
   、期待通りの結果を生成しないかもしれません。

   エラーの場合のためのコードを除き、デフォルトの "fromutc()" の実装は
   以下のように動作します:

      def fromutc(self, dt):
          # raise ValueError error if dt.tzinfo is not self
          dtoff = dt.utcoffset()
          dtdst = dt.dst()
          # raise ValueError if dtoff is None or dtdst is None
          delta = dtoff - dtdst  # this is self's standard offset
          if delta:
              dt += delta   # convert to standard local time
              dtdst = dt.dst()
              # raise ValueError if dtdst is None
          if dtdst:
              return dt + dtdst
          else:
              return dt

次の "tzinfo_examples.py" ファイルには、 "tzinfo" クラスの例がいくつか
載っています:

   from datetime import tzinfo, timedelta, datetime

   ZERO = timedelta(0)
   HOUR = timedelta(hours=1)
   SECOND = timedelta(seconds=1)

   # A class capturing the platform's idea of local time.
   # (May result in wrong values on historical times in
   #  timezones where UTC offset and/or the DST rules had
   #  changed in the past.)
   import time as _time

   STDOFFSET = timedelta(seconds = -_time.timezone)
   if _time.daylight:
       DSTOFFSET = timedelta(seconds = -_time.altzone)
   else:
       DSTOFFSET = STDOFFSET

   DSTDIFF = DSTOFFSET - STDOFFSET

   class LocalTimezone(tzinfo):

       def fromutc(self, dt):
           assert dt.tzinfo is self
           stamp = (dt - datetime(1970, 1, 1, tzinfo=self)) // SECOND
           args = _time.localtime(stamp)[:6]
           dst_diff = DSTDIFF // SECOND
           # Detect fold
           fold = (args == _time.localtime(stamp - dst_diff))
           return datetime(*args, microsecond=dt.microsecond,
                           tzinfo=self, fold=fold)

       def utcoffset(self, dt):
           if self._isdst(dt):
               return DSTOFFSET
           else:
               return STDOFFSET

       def dst(self, dt):
           if self._isdst(dt):
               return DSTDIFF
           else:
               return ZERO

       def tzname(self, dt):
           return _time.tzname[self._isdst(dt)]

       def _isdst(self, dt):
           tt = (dt.year, dt.month, dt.day,
                 dt.hour, dt.minute, dt.second,
                 dt.weekday(), 0, 0)
           stamp = _time.mktime(tt)
           tt = _time.localtime(stamp)
           return tt.tm_isdst > 0

   Local = LocalTimezone()


   # A complete implementation of current DST rules for major US time zones.

   def first_sunday_on_or_after(dt):
       days_to_go = 6 - dt.weekday()
       if days_to_go:
           dt += timedelta(days_to_go)
       return dt


   # US DST Rules
   #
   # This is a simplified (i.e., wrong for a few cases) set of rules for US
   # DST start and end times. For a complete and up-to-date set of DST rules
   # and timezone definitions, visit the Olson Database (or try pytz):
   # http://www.twinsun.com/tz/tz-link.htm
   # http://sourceforge.net/projects/pytz/ (might not be up-to-date)
   #
   # In the US, since 2007, DST starts at 2am (standard time) on the second
   # Sunday in March, which is the first Sunday on or after Mar 8.
   DSTSTART_2007 = datetime(1, 3, 8, 2)
   # and ends at 2am (DST time) on the first Sunday of Nov.
   DSTEND_2007 = datetime(1, 11, 1, 2)
   # From 1987 to 2006, DST used to start at 2am (standard time) on the first
   # Sunday in April and to end at 2am (DST time) on the last
   # Sunday of October, which is the first Sunday on or after Oct 25.
   DSTSTART_1987_2006 = datetime(1, 4, 1, 2)
   DSTEND_1987_2006 = datetime(1, 10, 25, 2)
   # From 1967 to 1986, DST used to start at 2am (standard time) on the last
   # Sunday in April (the one on or after April 24) and to end at 2am (DST time)
   # on the last Sunday of October, which is the first Sunday
   # on or after Oct 25.
   DSTSTART_1967_1986 = datetime(1, 4, 24, 2)
   DSTEND_1967_1986 = DSTEND_1987_2006

   def us_dst_range(year):
       # Find start and end times for US DST. For years before 1967, return
       # start = end for no DST.
       if 2006 < year:
           dststart, dstend = DSTSTART_2007, DSTEND_2007
       elif 1986 < year < 2007:
           dststart, dstend = DSTSTART_1987_2006, DSTEND_1987_2006
       elif 1966 < year < 1987:
           dststart, dstend = DSTSTART_1967_1986, DSTEND_1967_1986
       else:
           return (datetime(year, 1, 1), ) * 2

       start = first_sunday_on_or_after(dststart.replace(year=year))
       end = first_sunday_on_or_after(dstend.replace(year=year))
       return start, end


   class USTimeZone(tzinfo):

       def __init__(self, hours, reprname, stdname, dstname):
           self.stdoffset = timedelta(hours=hours)
           self.reprname = reprname
           self.stdname = stdname
           self.dstname = dstname

       def __repr__(self):
           return self.reprname

       def tzname(self, dt):
           if self.dst(dt):
               return self.dstname
           else:
               return self.stdname

       def utcoffset(self, dt):
           return self.stdoffset + self.dst(dt)

       def dst(self, dt):
           if dt is None or dt.tzinfo is None:
               # An exception may be sensible here, in one or both cases.
               # It depends on how you want to treat them.  The default
               # fromutc() implementation (called by the default astimezone()
               # implementation) passes a datetime with dt.tzinfo is self.
               return ZERO
           assert dt.tzinfo is self
           start, end = us_dst_range(dt.year)
           # Can't compare naive to aware objects, so strip the timezone from
           # dt first.
           dt = dt.replace(tzinfo=None)
           if start + HOUR <= dt < end - HOUR:
               # DST is in effect.
               return HOUR
           if end - HOUR <= dt < end:
               # Fold (an ambiguous hour): use dt.fold to disambiguate.
               return ZERO if dt.fold else HOUR
           if start <= dt < start + HOUR:
               # Gap (a non-existent hour): reverse the fold rule.
               return HOUR if dt.fold else ZERO
           # DST is off.
           return ZERO

       def fromutc(self, dt):
           assert dt.tzinfo is self
           start, end = us_dst_range(dt.year)
           start = start.replace(tzinfo=self)
           end = end.replace(tzinfo=self)
           std_time = dt + self.stdoffset
           dst_time = std_time + HOUR
           if end <= dst_time < end + HOUR:
               # Repeated hour
               return std_time.replace(fold=1)
           if std_time < start or dst_time >= end:
               # Standard time
               return std_time
           if start <= std_time < end - HOUR:
               # Daylight saving time
               return dst_time


   Eastern  = USTimeZone(-5, "Eastern",  "EST", "EDT")
   Central  = USTimeZone(-6, "Central",  "CST", "CDT")
   Mountain = USTimeZone(-7, "Mountain", "MST", "MDT")
   Pacific  = USTimeZone(-8, "Pacific",  "PST", "PDT")

標準時および夏時間の両方を記述している "tzinfo" のサブクラスでは、夏時
間の移行のときに、回避不能の難解な問題が年に 2 度あるので注意してくだ
さい。 具体的な例として、東部アメリカ時刻 (US Eastern, UTC -0500) を考
えます。 EDT は 3 月の第二日曜日の 1:59 (EST) の 1 分後に開始し、11 月
の最初の日曜日の (EDTの) 1:59 に終了します:

     UTC   3:MM  4:MM  5:MM  6:MM  7:MM  8:MM
     EST  22:MM 23:MM  0:MM  1:MM  2:MM  3:MM
     EDT  23:MM  0:MM  1:MM  2:MM  3:MM  4:MM

   start  22:MM 23:MM  0:MM  1:MM  3:MM  4:MM

     end  23:MM  0:MM  1:MM  1:MM  2:MM  3:MM

DSTの開始 ("start" ライン) で、ローカルの実時間は 1:59 から 3:00 に飛
びます。 この日には、 2:MM という形式の実時間は意味をなさないので、
DST が始まった日に "astimezone(Eastern)" は >>``<<hour == 2``となる結
果を返すことはありません。 例として、 2016 年の春方向の移行では、次の
ような結果になります:

   >>> from datetime import datetime, timezone
   >>> from tzinfo_examples import HOUR, Eastern
   >>> u0 = datetime(2016, 3, 13, 5, tzinfo=timezone.utc)
   >>> for i in range(4):
   ...     u = u0 + i*HOUR
   ...     t = u.astimezone(Eastern)
   ...     print(u.time(), 'UTC =', t.time(), t.tzname())
   ...
   05:00:00 UTC = 00:00:00 EST
   06:00:00 UTC = 01:00:00 EST
   07:00:00 UTC = 03:00:00 EDT
   08:00:00 UTC = 04:00:00 EDT

DST が終了 ("end" ライン) で、更なる問題が潜んでいます: ローカルの実時
間で、曖昧さ無しに時を綴れない 1 時間が存在します: それは夏時間の最後
の 1 時間です。 東部では、夏時間が終了する日の UTC での 5:MM 形式の時
間がそれです。 ローカルの実時間は (夏時間の) 1:59 から (標準時の) 1:00
に再び巻き戻されます。 ローカルの時刻における 1:MM は曖昧です。 そして
"astimezone()" は 2 つの隣り合う UTC 時間を同じローカルの時間に対応付
けて、ローカルの時計の振る舞いを真似ます。 東部の例では、 5:MM および
6:MM という形式の UTC 時刻は両方とも東部時刻に変換された際に 1:MM に対
応付けられますが、それ以前の時間は "fold" 属性を 0 にし、以降の時間で
は 1 にします。例えば、 2016 年での秋方向の移行では、次のような結果に
なります:

   >>> u0 = datetime(2016, 11, 6, 4, tzinfo=timezone.utc)
   >>> for i in range(4):
   ...     u = u0 + i*HOUR
   ...     t = u.astimezone(Eastern)
   ...     print(u.time(), 'UTC =', t.time(), t.tzname(), t.fold)
   ...
   04:00:00 UTC = 00:00:00 EDT 0
   05:00:00 UTC = 01:00:00 EDT 0
   06:00:00 UTC = 01:00:00 EST 1
   07:00:00 UTC = 02:00:00 EST 0

"fold" 属性が異なるだけの "datetime" インスタンスは比較において等しい
とみなされることに注意してください。

壁時間に関する曖昧さは、明示的に "fold" 属性を検証するか、 "timezone"
が使用されたハイブリッドな "tzinfo" サブクラスか、そのほかの絶対時間差
を示す "tzinfo" サブクラス(EST (-5 時間の絶対時間差) のみを表すクラス
や、 EDT (-4 時間の絶対時間差) のみを表すクラス)を使用すると回避できま
す。 このような曖昧さを許容できないアプリケーションは、このような手法
によって回避すべきです。

参考:

     "zoneinfo"
        "datetime" モジュールには (UTC からの任意の固定オフセットを扱
        う) 基本的な "timezone" クラスと、(UTC タイムゾーンのインスタ
        ンスである) "timezone.utc" 属性があります。

        "zoneinfo" brings the *IANA timezone database* (also known as
        the Olson database) to Python, and its usage is recommended.

  IANA タイムゾーンデータベース
     (しばしば tz、tzdata や zoneinfo と呼ばれる) タイムゾーンデータベ
     ースはコードとデータを保持しており、それらは地球全体にわたる多く
     の代表的な場所のローカル時刻の履歴を表しています。政治団体による
     タイムゾーンの境界、UTC オフセット、夏時間のルールの変更を反映す
     るため、定期的にデータベースが更新されます。


"timezone" オブジェクト
=======================

"timezone" クラスは "tzinfo" のサブクラスで、各インスタンスは UTC から
の固定されたオフセットで定義されたタイムゾーンを表しています。

このクラスのオブジェクトは、一年のうち異なる日に異なるオフセットが使わ
れていたり、常用時 (civil time) に歴史的な変化が起きた場所のタイムゾー
ン情報を表すのには使えないので注意してください。

class datetime.timezone(offset, name=None)

   ローカル時刻と UTC の差分を表す "timedelta" オブジェクトを *offset*
   引数に指定しなくてはいけません。これは "-timedelta(hours=24)" から
   "timedelta(hours=24)" までの両端を含まない範囲に収まっていなくては
   なりません。そうでない場合 "ValueError" が送出されます。

   The *name* argument is optional. If specified it must be a string
   that will be used as the value returned by the "datetime.tzname()"
   method.

   バージョン 3.2 で追加.

   バージョン 3.7 で変更: UTC オフセットが分単位でなければならない制限
   が無くなりました。

timezone.utcoffset(dt)

   "timezone" インスタンスが構築されたときに指定された固定値を返します
   。

   *dt* 引数は無視されます。 返り値は、ローカル時刻と UTC の差分に等し
   い "timedelta" インスタンスです。

   バージョン 3.7 で変更: UTC オフセットが分単位でなければならない制限
   が無くなりました。

timezone.tzname(dt)

   "timezone" インスタンスが構築されたときに指定された固定値を返します
   。

   *name* が構築時に与えられなかった場合、 "tzname(dt)" によって返され
   る name は以下の様に "offset" の値から生成されます。 *offset* が
   "timedelta(0)" であった場合、 name は "UTC"になります。 それ以外の
   場合、 'UTC±HH:MM' という書式の文字列になり、± は "offset" を、HH
   と MM はそれぞれ二桁の "offset.hours" と "offset.minutes" を表現し
   ます。

   バージョン 3.6 で変更: "offset=timedelta(0)" によって生成される名前
   はプレーンな *'UTC'* であり "'UTC+00:00'" ではありません。

timezone.dst(dt)

   常に "None" を返します。

timezone.fromutc(dt)

   "dt + offset" を返します。 *dt* 引数は "tzinfo" が "self" になって
   いる aware な "datetime" インスタンスでなければなりません。

以下にクラス属性を示します:

timezone.utc

   UTC タイムゾーン "timezone(timedelta(0))" です。


"strftime()" と "strptime()" の振る舞い
=======================================

"date", "datetime", "time" オブジェクトは全て "strftime(format)" メソ
ッドをサポートし、時刻を表現する文字列を明示的な書式文字列で統制して作
成しています。

逆に "datetime.strptime()" クラスメソッドは日付や時刻に対応する書式文
字列から "datetime" オブジェクトを生成します。

下の表は "strftime()" と "strptime()" との高レベルの対比を表しています
。

+------------------+----------------------------------------------------------+--------------------------------------------------------------------------------+
|                  | "strftime"                                               | "strptime"                                                                     |
|==================|==========================================================|================================================================================|
| 使用法           | オブジェクトを与えられた書式に従って文字列に変換する     | 指定された対応する書式で文字列を構文解析して "datetime" オブジェクトに する    |
+------------------+----------------------------------------------------------+--------------------------------------------------------------------------------+
| メソッドの種類   | インスタンスメソッド                                     | クラスメソッド                                                                 |
+------------------+----------------------------------------------------------+--------------------------------------------------------------------------------+
| メソッドを持つク | "date"; "datetime"; "time"                               | "datetime"                                                                     |
| ラス             |                                                          |                                                                                |
+------------------+----------------------------------------------------------+--------------------------------------------------------------------------------+
| シグネチャ       | "strftime(format)"                                       | "strptime(date_string, format)"                                                |
+------------------+----------------------------------------------------------+--------------------------------------------------------------------------------+


"strftime()" と "strptime()" の書式コード
-----------------------------------------

以下のリストは 1989 C 標準が要求する全ての書式コードで、標準 C 実装が
あれば全ての環境で動作します。

+-------------+----------------------------------+--------------------------+---------+
| ディレクテ  | 意味                             | 使用例                   | 注釈    |
| ィブ        |                                  |                          |         |
|=============|==================================|==========================|=========|
| "%a"        | ロケールの曜日名を短縮形で表示し | Sun, Mon, ..., Sat       | (1)     |
|             | ます。                           | (en_US); So, Mo, ..., Sa |         |
|             |                                  | (de_DE)                  |         |
+-------------+----------------------------------+--------------------------+---------+
| "%A"        | ロケールの曜日名を表示します。   | Sunday, Monday, ...,     | (1)     |
|             |                                  | Saturday (en_US);        |         |
|             |                                  | Sonntag, Montag, ...,    |         |
|             |                                  | Samstag (de_DE)          |         |
+-------------+----------------------------------+--------------------------+---------+
| "%w"        | 曜日を10進表記した文字列を表示し | 0, 1, ..., 6             |         |
|             | ます。0 が日曜日で、6 が土曜日を |                          |         |
|             | 表しま す。                      |                          |         |
+-------------+----------------------------------+--------------------------+---------+
| "%d"        | 0埋めした10進数で表記した月中の  | 01, 02, ..., 31          | (9)     |
|             | 日にち。                         |                          |         |
+-------------+----------------------------------+--------------------------+---------+
| "%b"        | ロケールの月名を短縮形で表示しま | Jan, Feb, ..., Dec       | (1)     |
|             | す。                             | (en_US); Jan, Feb, ...,  |         |
|             |                                  | Dez (de_DE)              |         |
+-------------+----------------------------------+--------------------------+---------+
| "%B"        | ロケールの月名を表示します。     | January, February, ...,  | (1)     |
|             |                                  | December (en_US);        |         |
|             |                                  | Januar, Februar, ...,    |         |
|             |                                  | Dezember (de_DE)         |         |
+-------------+----------------------------------+--------------------------+---------+
| "%m"        | 0埋めした10進数で表記した月。    | 01, 02, ..., 12          | (9)     |
+-------------+----------------------------------+--------------------------+---------+
| "%y"        | 0埋めした10進数で表記した世紀無  | 00, 01, ..., 99          | (9)     |
|             | しの年。                         |                          |         |
+-------------+----------------------------------+--------------------------+---------+
| "%Y"        | 西暦 ( 4桁) の 10 進表記を表しま | 0001, 0002, ..., 2013,   | (2)     |
|             | す。                             | 2014, ..., 9998, 9999    |         |
+-------------+----------------------------------+--------------------------+---------+
| "%H"        | 0埋めした10進数で表記した時 (24  | 00, 01, ..., 23          | (9)     |
|             | 時間表記)。                      |                          |         |
+-------------+----------------------------------+--------------------------+---------+
| "%I"        | 0埋めした10進数で表記した時 (12  | 01, 02, ..., 12          | (9)     |
|             | 時間表記)。                      |                          |         |
+-------------+----------------------------------+--------------------------+---------+
| "%p"        | ロケールの AM もしくは PM と等価 | AM, PM (en_US); am, pm   | (1),    |
|             | な文字列になります。             | (de_DE)                  | (3)     |
+-------------+----------------------------------+--------------------------+---------+
| "%M"        | 0埋めした10進数で表記した分。    | 00, 01, ..., 59          | (9)     |
+-------------+----------------------------------+--------------------------+---------+
| "%S"        | 0埋めした10進数で表記した秒。    | 00, 01, ..., 59          | (4),    |
|             |                                  |                          | (9)     |
+-------------+----------------------------------+--------------------------+---------+
| "%f"        | Microsecond as a decimal number, | 000000, 000001, ...,     | (5)     |
|             | zero-padded to 6 digits.         | 999999                   |         |
+-------------+----------------------------------+--------------------------+---------+
| "%z"        | UTCオフセットを                  | (空文字列), +0000,       | (6)     |
|             | "±HHMM[SS[.ffffff]]" の形式で表  | -0400, +1030, +063415,   |         |
|             | 示します (オブジェクト がnaiveで | -030712.345216           |         |
|             | あれば空文字列)。                |                          |         |
+-------------+----------------------------------+--------------------------+---------+
| "%Z"        | タイムゾーンの名前を表示します ( | (空文字列), UTC, GMT     | (6)     |
|             | オブジェクトがnaiveであれば空文  |                          |         |
|             | 字列)。                          |                          |         |
+-------------+----------------------------------+--------------------------+---------+
| "%j"        | 0埋めした10進数で表記した年中の  | 001, 002, ..., 366       | (9)     |
|             | 日にち。                         |                          |         |
+-------------+----------------------------------+--------------------------+---------+
| "%U"        | Week number of the year (Sunday  | 00, 01, ..., 53          | (7),    |
|             | as the first day of the week) as |                          | (9)     |
|             | a zero-padded decimal number.    |                          |         |
|             | All days in a new year preceding |                          |         |
|             | the first Sunday are considered  |                          |         |
|             | to be in week 0.                 |                          |         |
+-------------+----------------------------------+--------------------------+---------+
| "%W"        | Week number of the year (Monday  | 00, 01, ..., 53          | (7),    |
|             | as the first day of the week) as |                          | (9)     |
|             | a zero-padded decimal number.    |                          |         |
|             | All days in a new year preceding |                          |         |
|             | the first Monday are considered  |                          |         |
|             | to be in week 0.                 |                          |         |
+-------------+----------------------------------+--------------------------+---------+
| "%c"        | ロケールの日時を適切な形式で表し | Tue Aug 16 21:30:00 1988 | (1)     |
|             | ます。                           | (en_US); Di 16 Aug       |         |
|             |                                  | 21:30:00 1988 (de_DE)    |         |
+-------------+----------------------------------+--------------------------+---------+
| "%x"        | ロケールの日付を適切な形式で表し | 08/16/88 (None);         | (1)     |
|             | ます。                           | 08/16/1988 (en_US);      |         |
|             |                                  | 16.08.1988 (de_DE)       |         |
+-------------+----------------------------------+--------------------------+---------+
| "%X"        | ロケールの時間を適切な形式で表し | 21:30:00 (en_US);        | (1)     |
|             | ます。                           | 21:30:00 (de_DE)         |         |
+-------------+----------------------------------+--------------------------+---------+
| "%%"        | 文字 "'%'" を表します。          | %                        |         |
+-------------+----------------------------------+--------------------------+---------+

C89規格により要求されない幾つかの追加のコードが便宜上含まれています。
これらのパラメータはすべてISO 8601の日付値に対応しています。

+-------------+----------------------------------+--------------------------+---------+
| ディレクテ  | 意味                             | 使用例                   | 注釈    |
| ィブ        |                                  |                          |         |
|=============|==================================|==========================|=========|
| "%G"        | ISO week("%V")の内過半数を含む西 | 0001, 0002, ..., 2013,   | (8)     |
|             | 暦表記の ISO 8601 year です。    | 2014, ..., 9998, 9999    |         |
+-------------+----------------------------------+--------------------------+---------+
| "%u"        | 1 を月曜日を表す 10進数表記の    | 1, 2, ..., 7             |         |
|             | ISO 8601 weekday です。          |                          |         |
+-------------+----------------------------------+--------------------------+---------+
| "%V"        | 週で最初の月曜日を始めとする ISO | 01, 02, ..., 53          | (8),    |
|             | 8601 week です。Week 01 は 1月4  |                          | (9)     |
|             | 日を含 みます。                  |                          |         |
+-------------+----------------------------------+--------------------------+---------+

これらが "strftime()" メソッドと一緒に使用された場合、すべてのプラット
フォームで利用できるわけではありません。 ISO 8601 year 指定子およびISO
8601 week 指定子は、上記のyear および week number 指定子と互換性があり
ません。不完全またはあいまいなISO 8601 指定子で "strptime()" を呼び出
すと、 "ValueError" が送出されます。

The full set of format codes supported varies across platforms,
because Python calls the platform C library's "strftime()" function,
and platform variations are common. To see the full set of format
codes supported on your platform, consult the *strftime(3)*
documentation. There are also differences between platforms in
handling of unsupported format specifiers.

バージョン 3.6 で追加: "%G", "%u" および "%V" が追加されました。


技術詳細
--------

大雑把にいうと、 "d.strftime(fmt)" は "time" モジュールの
"time.strftime(fmt, d.timetuple())" のように動作します。ただし全てのオ
ブジェクトが "timetuple()" メソッドをサポートしているわけではありませ
ん。

"datetime.strptime()" クラスメソッドでは、デフォルト値は
"1900-01-01T00:00:00.000" です。書式文字列で指定されなかった部分はデフ
ォルト値から引っ張ってきます。 [4]

"datetime.strptime(date_string, format)" は次の式と等価です:

   datetime(*(time.strptime(date_string, format)[0:6]))

ただし、 "datetime.strptime" はサポートしているが "time.strptime" には
無い、秒未満の単位やタイムゾーンオフセットの情報が format に 含まれて
いるときは除きます。

"time" オブジェクトには、年、月、日の値がないため、それらを書式コード
を使うことができません。 無理矢理使った場合、年は "1900" に置き換えら
れ、月と日は "1" に置き換えられます。

"date" オブジェクトには、時、分、秒、マイクロ秒の値がないため、それら
の書式コードを使うことができません。 無理矢理使った場合、これらの値は
"0" に置き換えられます。

同じ理由で、現在のロケールの文字集合で表現できない Unicode コードポイ
ントを含む書式文字列の対処もプラットフォーム依存です。 あるプラットフ
ォームではそういったコードポイントはそのまま出力に出される一方、他のプ
ラットフォームでは "strftime" が "UnicodeError" を送出したり、その代わ
りに空文字列を返したりするかもしれません。

注釈:

1. 書式は現在のロケールに依存するので、出力値について何か仮定するとき
   は注意すべきです。フィールドの順序は様々で (例えば、"月/日/年" と "
   日/月/年") 、出力はロケールのデフォルトエンコーディングでエンコード
   された Unicode 文字列を含むかもしれません (例えば、現在のロケールが
   "ja_JP" だった場合、デフォルトエンコーディングは "eucJP" 、 "SJIS"
   、 "utf-8" のいずれかになりえます。 "locale.getlocale()" を使って現
   在のロケールのエンコーディングを確認します) 。

2. "strptime()" メソッドは [1, 9999] の範囲の年数全てを構文解析できま
   すが、 year < 1000 の範囲の年数は 0 埋めされた 4 桁の数字でなければ
   なりません。

   バージョン 3.2 で変更: 以前のバージョンでは、 "strftime()" メソッド
   は years >= 1900 の範囲の年数しか扱えませんでした。

   バージョン 3.3 で変更: バージョン 3.2 では、 "strftime()" メソッド
   は years >= 1000 の範囲の年数しか扱えませんでした。

3. "strptime()" メソッドと共に使われた場合、 "%p" 指定子は出力の時間フ
   ィールドのみに影響し、 "%I" 指定子が使われたかのように振る舞います
   。

4. "time" モジュールと違い、 "datetime" モジュールはうるう秒をサポート
   していません。

5. "strptime()" メソッドと共に使われた場合、 "%f" 指定子は 1 桁から 6
   桁の数字を受け付け、右側から0埋めされます。 "%f" は C 標準規格の書
   式文字セットの拡張です (とは言え、 datetime モジュールのオブジェク
   トそれぞれに実装されているので、どれででも使えます)。

6. naive オブジェクトでは、書式コード "%z" および "%Z" は空文字列に置
   き換えられます。

   aware オブジェクトでは次のようになります:

   "%z"
      "utcoffset()" は "±HHMM[SS[.ffffff]]" 形式の文字列に変換されます
      。ここで、 "HH" は UTC オフセットの時間を表す 2 桁の文字列、
      "MM" は UTC オフセットの分数を表す 2 桁の文字列、 "SS" は UTC オ
      フセットの秒数を表す 2 桁の文字列、 "ffffff" は UTC オフセットの
      マイクロ秒数を表す 6 桁の文字列です。 オフセットに秒未満の端数が
      無いときは "ffffff" 部分は省略され、オフセットに分未満の端数が無
      いときは "ffffff" 部分も "SS" 部分も省略されます。 例えば、
      "utcoffset()" が "timedelta(hours=-3, minutes=-30)" を返す場合、
      "%z" は文字列 "'-0330'" に置き換えられます。

   バージョン 3.7 で変更: UTC オフセットが分単位でなければならない制限
   が無くなりました。

   バージョン 3.7 で変更: "%z" 指定子が "strptime()" メソッドに渡され
   たときは、時分秒のセパレータとしてコロンが UTC オフセットで使えます
   。 例えば、 "'+01:00:00'" は 1 時間のオフセットだと構文解析されます
   。 加えて、 "'Z'" を渡すことは "'+00:00'" を渡すことと同等です。

   "%Z"
      In "strftime()", "%Z" is replaced by an empty string if
      "tzname()" returns "None"; otherwise "%Z" is replaced by the
      returned value, which must be a string.

      "strptime()" は >>``<<%Z``に特定の値のみを受け入れます:

      1. 使用しているマシンのロケールによる >>``<<time.tzname``の任意
         の値

      2. ハードコードされた値 "UTC``または``GMT"

      つまり、日本に住んでいる場合は "JST", >>``<<UTC``と``GMT``が有効
      な値であり、 >>``<<EST``はおそらく無効な値となります。無効な値の
      場合は >>``<<ValueError``を送出します。

   バージョン 3.2 で変更: "%z" 指定子が "strptime()" メソッドに与えら
   れた場合、 aware な "datetime" オブジェクトが作成されます。返り値の
   "tzinfo" は "timezone" インスタンスになっています。

7. "strptime()" メソッドと共に使われた場合、 "%U" と "%W" 指定子は、曜
   日と年("%Y")が指定された場合の計算でのみ使われます。

8. "%U" および "%W" と同様に、 "%V" は曜日と ISO 年 ("%G") が
   "strptime()" の書式文字列の中で指定された場合に計算でのみ使われます
   。 "%G" と "%Y" は互いに完全な互換性を持たないことにも注意してくだ
   さい。

9. "strptime()" メソッドと共に使われたときは、書式 "%d", "%m", "%H",
   "%I", "%M", "%S", "%J", "%U", "%W", "%V" の後ろに続ける 0 は任意で
   す。 書式 "%y" では後ろに続ける 0 は必須です。

-[ 脚注 ]-

[1] もし相対性理論の効果を無視するならば、ですが

[2] この暦法は、全ての計算における基本カレンダーである、 Dershowitz と
    Reingold の書籍 *Calendrical Calculations* における先発グレゴリオ
    暦 ("proleptic Gregorian") の定義に一致します。 先発グレゴリオ暦の
    序数とその他多くの暦法どうしの変換アルゴリズムについては、この書籍
    を参照してください。

[3] 優れた説明は R. H. van Gent の guide to the mathematics of the ISO
    8601 calendar を参照してください。

[4] "1900" は閏年ではないので "datetime.strptime('Feb 29', '%b %d')"
    を渡すと失敗します。
