ISO 19103 Time

ISO 8601

[6] ISO 8601 は、日付時刻の表現形式に関する ISO国際標準です。 日時情報交換に使えるいくつかの構文 (日時形式) を定義しています。

[182] 例えばグレゴリオ暦西暦2016-03-25 と表現できる、といったことが規定されています。

[168] ISO 8601 は、日時に関する様々な対象を記述したり、様々な応用分野で利用したりできるように、 多くの選択肢のある“緩い”仕様を提示しています。実際には、利用する場面ごとにより具体的な仕様を (情報交換の当事者間の合意により) 確定する必要があり、それをプロファイルと呼ぶことがあります。 ISO 8601のプロファイルは、色々な場面で使われています。

[175] 自然言語文では、歴史と文化により様々な日時表現が用いられています。 しかし日米欧年月日の順序が異なるなど、その表記の揺れは大きく、 相互運用可能情報交換のためには何らかの基準が必要です。 ISO 8601 はそのような基準として色々な場面で採用されています。

[176] しかし、いつでもどこでもむやみに ISO 8601 の日時形式を採用するべきとも言えません。 例えば ISO 8601 の規定に従えば日付と時刻の間には「T」と記載することになります (2016-03-25T12:18 と表記します。) が、 人間が対象読者なら、この表記は一般的ではありませんから、奇妙に思われるでしょう。 時刻を「time」と呼ぶ英語圏ですら、この表記は (人間対象には) 普及していません。

[248] 一部で誤解があるような、すべての日時表示を統一しようと志向するものではありませんし、 そのような施策も知られていません。

目次

  1. 仕様書
    1. 表記法
  2. 暦法
  3. 表現
  4. 日時書式表現
  5. 日付の表現
  6. 時の表現
  7. 時差の表現
  8. 日時の表現
  9. 時間長の表現
    1. 代替形式
    2. 派生
  10. 時間間隔の表現
    1. 開始と終了による表現
    2. 時間長と文脈による表現
    3. 開始と時間長による表現
    4. 時間長と終了による表現
  11. 反復時間間隔の表現
  12. 指示子
  13. 先導0
  14. 文字と記号
    1. ハイフンとマイナス
    2. 小数点
    3. 斜線
    4. T
    5. W
  15. プロファイルと変種
    1. 主要プロファイルの比較
    2. プロファイルや変種の例
      1. RFC 3339 の ISO 8601 構文
    3. その他の応用
  16. 各国版
    1. 米国
    2. JIS X 0301
    3. CNS 7648
    4. TIS 1111
    5. 国連
    6. その他
  17. 構文解析
  18. 関連
  19. 歴史
    1. ISO 日時標準の制定
    2. ISO 8601 の制定
  20. メモ

仕様書#

[37] ISO 8601>>38 から入手できますが、有料です。

[247] 本気で普及させようとしているのでしょうか? 規格票の販売で標準化するビジネスモデルが過去のものになってもはや何十年も経過しています。

[325] 開発は ISO/TC 154/WG 5 が担当しています。

表記法#

[45] ISO 8601 では地の文日時表現日時書式表現を区別するために、 表現 (representation) を「[」と「]」で括っています。この括弧は仕様書の表現上のもので、 表現の一部ではないとされています。 >>7 Introduction

[244] 実際 ISO 8601 以外でこの表記法はあまり見かけません。

暦法#

[219] ISO 8601先発グレゴリオ暦を採用しています。 先発グレゴリオ暦グレゴリオ暦ISO 8601の年

[250] ISO 8601 本体は西暦年にだけ対応しています。 他の紀年法は利用できません。

[251] ただし ISO 8601 の各国版は、 当該国の紀年法に対応している場合があります (>>234)。

[364] ISO 8601週暦は、通称ISO週暦と呼ばれるものです。

表現#

[126] ISO 8601日時などを記述した文字列のことを表現 (representation) と呼んでいます。 ISO 8601 では次のような表現が定義されています。

  • 日時表現
    • 日付の表現
    • 時刻の表現
    • 時差の表現
    • 日時の表現
    • 時間長の表現
    • 時間間隔の表現
    • 反復時間間隔の表現
  • 日時書式表現

[26] 日時表現 (date and time representation) は、 時間点時間間隔反復時間間隔を示す表現 (representation) です >>7 2.3.1

[36] 日時表現は精度や値域によって次のように分類されています。

  • [32] 完全表現 (complete representation) は、 当該表現を構成するすべての日時の要素を含めた表現です。 >>7 2.3.5
    • 要素としてはすべて含まれますが、5桁以上の年や小数部は含まれません。
  • [33] 小数付き表現 (decimal representation) は、 構成する下位の部品に小数を加えたものです。 >>7 2.3.6
  • [34] 精度を削減した表現 (representation with reduced accuracy) は、 下位の部品を省略したものです。 >>7 2.3.7
  • [35] 展開表現 (expanded representation) は、 0年より前や9999年より後の暦年を表現できるようにしたものです。 >>7 2.3.8
  • [141] 切り詰めた表現 (truncated representation) は、 構成する上位の部品を省略したものです。 ISO 8601:2000 4.6

[127] 完全表現は、週による表記と月日による表記のように、複数存在することがあります。 それ以外の表現も、月までの精度の表現と年までの精度の表現のように、複数存在することがあります。 月までの精度で年を展開した表現のように、複数に該当する表現もあり得ます。

[130] 複数の表現を組み合わせて構成される表現では、違った精度の表現を混在させることができます。 例えば日時を表す際に、日付完全表現時刻精度を削減した表現を組み合わせることができます (もちろんそれは日時完全表現ではありません)。

[69] また記号の有無によって次の分類があります。

[30] 基本書式は、平文では避けるべきです >>7 2.3.3 NOTE

[128] 基本書式拡張書式がある場合、拡張書式から特定の分離子を除去したものが基本書式になっています。 除去できる分離子がない場合には、拡張書式はありません。

[131] 複数の表現を組み合わせて構成される表現では、基本書式拡張書式を混在させることは禁止されています。

[132] 24時間制の普及によって分離子は必要なくなった >>7 Annex A という見方により、数字のみで構成される方が「基本」で、分離子が含まれる方が「拡張」 とされているようです。 (この考え方が世間一般で通用するかは甚だ疑問です。)

[129] 表現や書式の種類は沢山ありますが、基本的にはどれが良いとかどれが優れているといったような区別ではなく、 必要に応じて使い分けることが想定されているようです。

[160] ISO 8601//ABNF に、日時表現ABNF で表したものがあります。

日時書式表現#

[28] 日時書式表現 (date and time format representation) は、 日時表現の群の書式を説明する表現 (representation) です >>7 2.3.2

[46] これは一種のパターン言語で、 ISO 8601 仕様書で日時表現の構文を定義する >>7 3.3 ためのものですが、情報交換において日時表現がどのように記述されているかを示すために用いることもできます。

[147] 例えば YYYY-MM という日時書式表現は、 2000-031985-120003-01 などの年月の日時表現を表しています。

[47] 情報交換の当事者間の合意により、日時書式表現を転送しても構いません >>7 3.3, >>7 5。 その場合 ISO 8601 により認められた日時書式表現のみを用いなければなりません >>7 3.3。 また、情報交換の当事者間の合意により認められた日時表現に対応する日時書式表現のみ用いなければなりません >>7 5

[51] ITU-T S.1 レパートリ (telex など) を用いる環境では、 日時書式表現を用いてはなりません。 >>7 3.4.1

[54] 日時書式表現では、次の文字を使います >>7 3.4.2

文字意味
Y数字
M数字
D数字
w数字
h数字
m数字
s数字
n正数または0数字

[55] ± は、正数または0+ または負数マイナスを表します >>7 3.4.2。ただし ± を使えない環境では、日時書式表現± を含められません >>7 3.4.1

[86] 0 を表すためにマイナスを用いることは認められていません。

[48] 下線は、日時表現においてそれに相当する部分が複数文字に展開され得ることを表します >>7 3.3>>54数字を表す文字下線があると、それが0文字以上であることを表します >>7 3.4.2日時書式表現情報交換の時点で文字数がわかっている時には、下線を用いてはなりません >>7 3.3, >>7 5文字下線を付けられない環境では、文字の前に下線を置かなければなりません >>7 3.4.1

[245] 例えば nnn_n は、1桁以上の数字非負整数を記述したものです。

[56] その他の文字は、日時表現でも同じ文字を表します >>7 3.4.2

[133] JIS X 0301 による拡張では、 N元号の記号を表します >>27 5.1.3

日付の表現#

[70] 暦日付に関しては、次の表現が定義されています >>7 4.1.2

基本形式拡張形式
完全表現 - YYYYMMDDYYYY‐MM‐DD
精度を削減した表現 - YYYY‐MMなし
精度を削減した表現 - YYYYなし
精度を削減した表現 - 世紀YYなし
展開表現 - ±_YYYYYMMDD±_YYYYY‐MM‐DD
展開表現 - 精度を削減した表現 - ±_YYYYY‐MMなし
展開表現 - 精度を削減した表現 - ±_YYYYYなし
展開表現 - 精度を削減した表現 - 世紀±_YYYなし

[72] 通日日付に関しては、次の表現が定義されています >>7 4.1.3

基本形式拡張形式
完全表現 - YYYYDDDYYYY‐DDD
展開表現 - ±_YYYYYDDD±_YYYYY‐DDD

[73] 週日付に関しては、次の表現が定義されています >>7 4.1.4

基本形式拡張形式
完全表現 - YYYYWwwDYYYY‐Www‐D
精度を削減した表現 - YYYYWwwYYYY‐Www
展開表現 - ±_YYYYYWwwD±_YYYYY‐Www‐D
展開表現 - 精度を削減した表現 - ±_YYYYWww±_YYYY‐Www
[74]W」はそのまま日時表現に現れます (>>367)。

[344] 暦日付完全表現ISO 8601 の前身の1つ ISO 2014 に由来します。 は4桁でなければならない (shall) のが原則で、 明確な時は2桁にすることができると NOTE にありました。 >>339

[374] 通日日付完全表現ISO 8601 の前身の1つ ISO 2711 に由来します。

year () と day of year (年の日) はそれぞれ別個に使ってもよく、 この順で組合せて使っても良いとされていました。 >>371

は4桁ですが、2桁の year of century (世紀の年) や 1桁の year of decade (十年紀の年) とする選択肢も認められていました。 >>371

[375] ISO 2711通日日付機械処理で便宜上用いられることがあるとし、 その他の目的には ISO/R 2014暦日付を使わなければならない (shall) としていました。 >>371


[135] JIS X 0301元号による日付の表現も定義しています >>27 5.2.4

基本形式拡張形式
完全表現 - YY.MM.DDNYY.MM.DD
[136] ここで .小数点ではなく、 ピリオド >>27 5.2.4 とされています (>>139)。
[137] 完全表現以外は定義されていないようです。また、他の表現との組み合わせも定義されていないようです。 (日時を組み合わせた表現すら定義されていませんが、いいのでしょうか。。。)

[319] ISO8601(X0301)の桁数拡張: suchowan's blog, https://suchowan.at.webry.info/201309/article_6.html

[320] ISO8601(X0301)用オプション: suchowan's blog, https://suchowan.at.webry.info/201312/article_11.html

時の表現#

[75] 地方時に関しては、次の表現が定義されています >>7 4.2.2

基本形式拡張形式
完全表現 - hhmmsshh:mm:ss
精度を削減した表現 - hhmmhh:mm
精度を削減した表現 - hhなし
小数付き表現 - hhmmss,s_s hh:mm:ss,s_s
小数付き表現 - 精度を削減した表現 - hhmm,m_mhh:mm,m_m
小数付き表現 - 精度を削減した表現 - hh,h_hなし

[144] 以前は更に次の表現が定義されており、情報交換の当事者間の合意により用いることができました ISO 8601:2000 5.3.1.4

基本形式拡張形式
切り詰めた表現 - 省略‐mmss‐mm:ss
切り詰めた表現 - 精度を削減した表現 - 省略‐mmなし
切り詰めた表現 - 精度を削減した表現 - 省略‐‐ssなし
切り詰めた表現 - 小数付き表現 - 省略‐mmss,s_s‐mm:ss,s_s
切り詰めた表現 - 小数付き表現 - 精度を削減した表現 - 省略‐mm,m_mなし
切り詰めた表現 - 小数付き表現 - 精度を削減した表現 - 省略‐‐ss,s_sなし

[145] なおこれらの先頭の省略を表す - は、曖昧でない場合省略できるとされていました ISO 8601:2000 4.6, 5.3.1.4

[381] ISO 8601 の前身の1つ ISO 3307 は、 00 から 23 としていました (24 は不可)。 00 から 59 としていました (閏秒60, 61 は不可)。 >>376

[382] 次の組み合わせが認められていました。 >>376

[81] 日のUTC (UTC of day) に関しては、 >>75 の各表現の後に UTC指示子 (UTC designator) Z を付けたものが定義されています >>7 4.2.4

[87] 地方時と、地方時UTC時差を示す必要がある時は、 地方時の直後に時差の表現を続けることができます >>7 4.2.5.2

[90] 地方時においては空文字列日のUTCにおいては UTC指示子 Z時差付きの場合においては時差のことを時間帯指示子 (zone designator) といいます >>7 4.3.2

[76] 地方時の表現 (>>75) の前に時刻指示子 T を付けた時刻指示子付き表現 (representation with time designator) を用いることができます。 文脈上地方時の表現であるか不明瞭な場合には、これを用いなければなりません。 >>7 4.2.2.5

[82] 日のUTCの表現 (>>81) や時差付きの表現 (>>87) と時刻指示子の併用については言及がありません。 (UTC指示子時差により明確に時刻と判断できるからでしょうか。)

[389] ISO 8601 の前身の1つ ISO 3307 は、 無指定で local time (地方時)、 Z 付きで UTC の2種類を定めていました。 時差の指定はできませんでした。 >>376

[194] 閏秒もあります。

時差の表現#

[83] 地方時日のUTC時差に関しては、次の表現が定義されています >>7 4.2.5.1

基本形式拡張形式
±hhmm±hh:mm
±hhなし

[85] 地方時の表現とは違って、を省略できるのは、が 0 になるときだけです >>7 4.2.5.1精度を削減した表現小数付き表現はありません。

[84] 時差地方時の表現と併用するもので、単独での利用は禁止されています >>7 4.2.5.1

[185] RFC 3339の日時形式-00:00 に特別な意味を与えていますが、 ISO 8601 にはそのような規定はなく、ローカルルールです。 (そうしたローカルルールが ISO 8601 により認められるかどうか、 議論の余地があります。)

[394] ISO 8601 の前身の1つ ISO 4031 は、 TDF (time differential factor) として ±hhmm / ±hh:mm 相当のものを規定していました。 >>390

[395] : が認められるのか規定本文では若干心もとないのですが、 例示で有無両パターンが明記されています。 >>390

[396] UTC との時差 -1200 から +1300 までがある、 と説明されていました。 >>390 規定なのか制定当時の事実の提示に過ぎないのか不明瞭ですが、 そう書かれているとこの範囲のみ対応すれば十分と思ってしまいそうです。

[397] 本規格は ISO 2014, ISO 2711, ISO 3307 と併用すると書かれていました。 >>390 具体的に例示されているのは ISO 3307 の時刻の構文との併用だけで、 暦日付通日日付との併用の可否や方法はよくわかりません。

日時の表現#

[88] 日時に関しては、次のいずれかの日付の表現 (完全表現または展開表現) の後に時刻指示子 T の後に >>75>>81>>87 のいずれかの時刻の表現が来るものが定義されています >>7 4.3

基本形式拡張形式
YYYYMMDDYYYY‐MM‐DD
±_YYYYYMMDD±_YYYYY‐MM‐DD
YYYYDDDYYYY‐DDD
±_YYYYYDDD±_YYYYY‐DDD
YYYYWwwDYYYY‐Www‐D
±_YYYYYWwwD±_YYYYY‐Www‐D
[161] 日付精度を削減した表現を使うことはできません。 (時刻では使えます。)
[162] ISO 8601:2000 では、日付切り詰めた表現が認められていました ISO 8601:2000 5.4.2。 (時刻では使えません。)
[89] 日時共に完全表現であるものが、日時完全表現です >>7 4.3.2

[91] 時刻指示子 T は、情報交換の当事者間の合意があれば、 曖昧でない場合省略できます。 >>7 4.3.2 NOTE

[92] 日時基本形式拡張形式を混在させることはできません >>7 4.3.3

時間長の表現#

[100] ISO 8601の時間長形式としては、次の表現が定義されています >>7 4.4.3

[105] 値が0なら、その値と直後の指示子は省略できます。がすべて省略されるなら、 T も省略しなければなりません。しかしすべて省略して P のみとしてはなりません。 >>7 4.4.3.2

[104] 数字列が、その直後の指示子を単位とする時間長の値と解釈されます。 全体としては個々の時間長を表します。

[103] 数字列の最大桁数は、情報交換の当事者間の合意によります >>7 4.4.3.2

[101] 時間長の表現は時間間隔循環時間間隔の一部として使われるもので、 単独での利用を推進するものではない >>7 4.4.3.2 とされています。

[102] 実際にはむしろ時間間隔よりも時間長単独での方が用いられているようです。

代替形式#

[107] 情報交換の当事者間の合意により、代替形式 (alternative format) を用いることもできます。 これは日時の表現の前に P を付けたものです。 >>7 4.4.3.3

[108] ここに示したものの他に、基本書式精度を削減した表現小数付き表現展開表現も認められているようです。

[165] 展開表現は意味をなさなそうですが、それも認められているのかは不明です。

[109] ただしこれらは日付としてではなく、時間長として扱われるため、値域が違っています。 は 0 から始まります。また 12月、30日、24時、60分、60秒は認められないようです。 >>7 4.4.3.3

[110] 通日日付の場合が明記されていませんが、364日までOKでしょうか。暦日付との整合性を考えると 359日までOKかもしれません。
[119] による表記が認められていないのは、1年が52週か53週か決められないから >>7 4.4.3.3 NOTE とされています。

派生#

[242] TM_PeriodDurationISO 8601の時間長形式を使ったデータ型です。 構文を制限し、グレゴリオ暦UTC 以外にも拡張しています。

時間間隔の表現#

[93] ISO 8601の時間間隔形式は、

... の4種類の方法で記述できます >>7 4.4.1。このうち >>94>>96>>97 は完結した情報ですが、 >>95時間のみで構成される不完全な time interval 情報で、 その意味を解釈するためには何らかの文脈情報が必要です。

日時/日時時間長時間長/日時

開始と終了による表現#

[111] 日時の表現を、開始と終了で2つ並べて、/ で区切ったものです。

[112] すべて基本書式、またはすべて拡張書式で構成されなければなりません >>7 4.4.4.1, >>7 4.4.4.5, >>7 4.4.5

[113] 両者の前後関係は明記されていませんが、開始と終了ですから、前者が後者以下でなければならないものと思われます。

[121] 終了側の上位側が省略されていれば、開始側と同じ値とみなされます >>7 4.4.5

[122] 例えば 1985-04-12/06-25 は、1985年4月12日から1985年6月25日を表します >>7 B.1.4

[124] 省略の仕方によっては何を表すのかわからなくなりますが、どこまで省略できるのか、 どう解釈するべきなのかは記述されていません。例えば基本書式で上位を省略したものと下位を省略したものは区別がまったくできないケースがあります。 また拡張書式でも、まで省略して分と秒だけのものと、 T まで省略して時と分だけで秒がないものは、 区別できないケースが有ります。
[159] 流石に日時とも省略されて時差だけ残るケースは認められないと思うのですが、どうでしょうか。

[120] 開始側にUTC指示子時差が含まれていて、終了側に含まれていなければ、 開始側の時間帯が終了側にも適用されます >>7 4.4.5

[123] 精度を削減する時に前後で精度が一致していなければならないという規定はありませんから、 1098-01-05/1993-03-05T00:12:44 のような表現も良いことになります。


[308] RKMSの時間範囲形式は、不明を表すために開始と終了の一方を省略可能とした拡張でした。

[309] Date Ranges (Dublin Core) は、 W3C-DTF に限定しつつ、開始と終了の一方を省略可能とした拡張でした。

時間長と文脈による表現#

[114] 時間長の表現によって、時間間隔の表現とするものです >>7 4.4.4.2, >>7 4.4.4.5, >>7 4.4.5

開始と時間長による表現#

[115] 開始の日時の表現と時間長の表現を並べて、 / で区切ったものです。

[116] すべて基本書式、またはすべて拡張書式で構成されなければなりません >>7 4.4.4.3, >>7 4.4.4.5, >>7 4.4.5

時間長と終了による表現#

[117] 時間長と終了の日時の表現を並べて、 / で区切ったものです。

[118] すべて基本書式、またはすべて拡張書式で構成されなければなりません >>7 4.4.4.4, >>7 4.4.4.5, >>7 4.4.5

反復時間間隔の表現#

[125] 反復時間間隔は、 R、反復数、/時間間隔の順に並べて表現します。 反復数を省略した場合は、無制限の反復を表します。 >>7 4.5

R/時間間隔

指示子#

[57] 日時表現 (や日時書式表現) にはラテン文字がしばしば登場しますが、 これは指示子 (designators) >>7 3.4.3 と呼ばれています。

[148] P,R, T, W, Z が使われています >>7 3.4.3

[58] 更に時間の表現では、 Y, M, W, D, H, S指示子として使われます >>7 3.4.3

[149] Mとしてもとしても使われます。
[59] Y, M, D日時書式表現 (>>54) では違う意味になっています。

[134] JIS X 0301 の拡張では、 Mなど (>>172) を元号を表す記号として使っています >>27 5.1.3

[138] ラテン文字漢字の使い分けは、定義されていません。

先導0#

[65] 時刻要素で長さが決まっている場合には、必要なら先導0を用いなければなりません >>7 3.6

[71] 可変長の部分では先導0は禁止されていないようです。

[163] 先導0によって解釈が曖昧となることもあります。

[164] 例えば25世紀を表す 25展開表現である +0025 は、 25を表す 0025展開表現である +0025 と区別できません。

文字と記号#

[150] 日時書式表現における ± (>>55)、 / の代替のダブルハイフン (>>98)、 特殊な扱いであるハイフンマイナス (>>49)、 JIS X 0301 による拡張である元号 (>>134) という多くの例外を除き、 ISO 8601 の表現で用いられる文字は、 ISO/IEC 646ASCII で表現できます。

[52] 日時表現では、大文字が使えない場合、小文字を使って構いません。 >>7 3.4.1 NOTE 1

[380] ISO 8601 の前身の1つ ISO 3307 は、 Z がないでは z とするべき (should) としていました。 >>376

[60] 日時書式表現では大文字小文字の違いによって意味が変わることがあります。

[53] 空白 (space) は、明示的に認められた場合を除き、使ってはなりません。 >>7 3.4.1 ただし ISO 8601 で明示的に認めている箇所はありません。

[370] >>345 も参照。

[63] : は、の区切りに使います >>7 3.4.4

[140] ISO 8601:2000 では # も定義されています ISO 8601:2000 4.5 が、例示にあるだけで、 実際には利用されていません。反復時間間隔において何度目の反復であるかを識別する際の区切子として使うことが想定されていたようです。 ISO 8601:2004 には含まれていません。

ハイフンとマイナス#

[61] マイナスは、日時書式表現± に相当する日時表現の部分で使って、 負数を表します。

[62] ハイフンは、の間の区切りとして使います >>7 3.4.4

[49] ハイフンマイナスは、 ISO/IEC 646 を元にした文字レパートリにあっては、 HYPHEN-MINUS を用います。 >>7 3.4.1

[50] ISO/IEC 10646Unicode がそのような文字レパートリと言えるのかは不明です...

[345] ISO 2014ISO 2711ハイフンまたは間隔を認めていました。 >>339, >>371

小数点#

[77] 小数点整数部小数部を分けるために使います。 値が1に満たない時は整数部を 0 や 00 にしなければなりません。 小数点がある時は小数部は1桁以上必要です。 >>7 4.2.2.4, >>7 4.4.3.2

[78] 小数点, または . を用いることができます。 ,より好ましい (preferred) とされています。 >>7 4.2.2.4, >>7 4.4.3.2

[379] ISO 8601 の前身の1つ ISO 3307 は、 ISO 31/0 を引いて、 小数点,英語では . でも良いとしていました。 >>376

[79] ISO 8601日時書式表現や例示の日時表現はすべて , に統一されています。

[80] しかし XML Schemaの日付形式HTMLの日付形式など主要なプロファイルはすべて . を採用しています。

[139] JIS X 0301 によって拡張された元号による日付の表現では、 ピリオド >>27 5.1.3 を用いています。これは , ではなく、 . でなければなりません。

斜線#

[64] / は、time intervalrecurring time interval の区切りに使います >>7 3.4.4, >>7 4.4.2 a)

[98] 応用分野によっては、 / のかわりに二重ハイフンを使うことがあります >>7 4.4.2 NOTE

[99] 「使うことがある」というのが、情報交換の当事者間の合意によって代用しても良いということなのか、 どういう意味なのか、はっきりしません。

T#

[391] ISO 8601 の前身の1つ ISO 3307 は、 ISO/R 2014 と組合せた日時の表現について、 区切子なしで連結できるものとし、 区切子が必要な場合はハイフンまたは間隔を使えるとしていました。 >>376

W#

[367] 週番号の前には W を書きます (>>73)。

[368] ISO 8601 の前身の1つ ISO 2015 は、 週番号の前に、週番号であることを明示する記号を書けるとしていました。 その表現は言語によるとしながらも、 W 01W 1 のように W (week) を使った例が示されていました。 >>346

[366] 国連版規格の W の表記が揺れている (>>329) のは、これと関係しているのかもしれません。

[369] ISO 8601 はこのような間隔の挿入を認めていません (>>53)。

プロファイルと変種#

[66] ISO 8601日時表現日時書式表現について、多くのバリエーションを定義していますし、 情報交換の当事者間の合意によって様々なオプションを採用できるとしています。 そのため様々なISO 8601のプロファイルが存在しています。

[68] 情報交換の当事者間の合意によって何らかの表現を採用する場合、 他の表現が曖昧無く区別できるように注意する必要があります >>7 3.7

[151] 不思議なことに全体としての適合性の規定がありませんが、明らかに、 仕様上認められ得るすべての表現を生成したり、理解したりすることは求められておらず、 応用分野と当事者間の合意によって必要な範囲の構文に対応するべきであると解するのが妥当でしょう。

[152] 実際、情報交換の当事者間の合意によって認められる構文の採用の仕方によっては、 何を意味するか曖昧性が生じてしまうことがありますから、 無条件に任意の入力を受け付けるような実装は作れません。

[153] プログラミング言語プロトコルその他各種の応用分野において、 ISO 8601 の一部機能を選択したり、それを元に拡張したりしたものが存在します。 その粒度は様々で、自由度が高いものもあれば、一意に表現が定まるようなものもあります。

[154] ISO 8601 を参照して定義されているものもあれば、完全に独自に互換な表現を定義しているものもあります。

[155] ISO 8601 はそのようなプロファイルの適合性を定義していませんから、 どれだけ制限や改変を加えても ISO 8601 に適合していると主張できるのかははっきりしません。

[156] 例えば RFC 3339の日付形式TZ小文字でも良いとしていますが、 ISO 8601 では >>52 の通り小文字による代用こそ認められていますが、 混在させると ISO 8601 に適合しないかもしれません。

[157] xs:dateTime では5桁以上のを認めていますが、その前に + を書くことができませんから、完全表現でも展開表現でもありません。 ISO 8601 に適合しない拡張ということになります。

[158] xs:gYear時差を組み合わせていますが、 ISO 8601 ではこのような組み合わせ方は定義されていません。

[212] 困ったことに、 ISO 8601 のうちの一部の機能のみを採用したものを 「ISO 8601 形式」のように呼ぶ人が少なくありません。 実際に ISO 8601 のどの一部を採用するかはものにより異なっていますし、 そのようないい加減な文書はまともに説明していないので、 文脈や例示、実装状況などから何を表しているか推測するしかありません。

主要プロファイルの比較#

[25] 主要なプロファイルの違いは次のようになっています。

年のみ年月のみ年月日のみ負の年0年5桁以上の年日時区切り24時秒の省略秒の小数部閏秒時間帯UTC時間帯の範囲-00:00
HTMLの日時形式××T / U+0020×指定可なし時刻ありなら指定可Z0-23禁止
XML Schemaの日時形式 (1.0)紀元前×先導0禁止T×指定可なし指定可Z0-14特記なし
XML Schemaの日時形式 (1.1)先導0禁止T×指定可なし指定可Z0-14特記なし
RFC 3339の日付形式×××××T / t / 任意××指定可60まで必須Z / z0-23「不明」
W3C-DTF××T×指定可なし時刻ありなら必須Z記載なし特記なし
詳細はそれぞれの項を参照。

プロファイルや変種の例#

[9] RFC 3339の日付形式は、特定の日時を表す部分集合で、 新しい IETF の技術ではこれを採用することが推奨されています。

[10] XML Schema の仕様書第2部ではいろいろな基本的なデータ型を規定していますが、 その中には RFC 3339 の日付形式に極めてよく似たものを含め、 いくつかの日付や時刻や時間の表現のための形式が定義されています。

[23] HTMLの日付形式のいくつかは、 ISO 8601 をもとに定義されています。

[24] JavaScriptの日付形式には、 ISO 8601の日付形式プロファイルが含まれています。

[11] W3C Member Submission Note である Date and Time Formats は、 RFC 3339の日付形式を同じものや、それよりも精度が低いもの (時刻を省略したものなど) など数種類の形式 (通称 W3C-DTF) を提案しています。 HTML 4 などが採用していますが、 XML Schema データ型の登場により現在では時代遅れであると考えられています。

[4] RFC 2326の時刻形式の1つ、 npt-range は、 ISO 8601 に従った書式で、演奏時間範囲を指定するのに使われます。

[5] PICSの日付形式は2種類あり、そのうちの新しい方は ISO 8601 に基づく書式です。 XML Schema のデータ型のものと似ていますが、 微妙に異なります。

[14] XLIFF 1.1 Specification (2006-07-08 02:30:08 +09:00 版) http://www.oasis-open.org/committees/xliff/documents/cs-xliff-core-1.1-20031031.htm#date

[22] XLIFF 1.2 Specification ( 版) http://docs.oasis-open.org/xliff/v1.2/os/xliff-core.html#date

[15] Global Information Management eXchange Metrics Volume 1.0 Specification (2007-02-24 17:44:10 +09:00 版) http://www.lisa.org/standards/gmx/GMX-V.html#Attr_date

>>14 の関連規格だけど日付形式は違う (名無しさん)

[16] TMX Specification (2007-02-24 17:51:20 +09:00 版) http://www.lisa.org/standards/tmx/tmx.html#changedate (名無しさん)

[17] TMX Specification (2007-02-24 17:51:20 +09:00 版) http://www.lisa.org/standards/tmx/tmx.html#creationdate (名無しさん)

[18] TMX Specification (2007-02-24 17:51:20 +09:00 版) http://www.lisa.org/standards/tmx/tmx.html#lastusagedate (名無しさん)

[19] XML Text Memory Namespace 1.0 Specification (2007-02-24 17:56:51 +09:00 版) http://www.lisa.org/standards/xmltm/xml-tm.html#Attr_date (名無しさん)

[20] TermBase eXchange Link (TBX Link) Specification ( 版) http://www.lisa.org/standards/tbxlink/tbxlink.html#Attr_date

[12] PICSの日付形式は2種類あり、そのうちの古い方は ISO 8601 に基づいた書式であることを意図していましたが、 日付の部分の区切子に誤って HYPHEN-MINUS ではなく FULL STOP を使っていました。 (新しい方の書式では修正されています。)

[13] ISO 8601 の日本版規格である JIS X 0301 (>>39) は、 ISO 8601 に加えて元号を使った和暦年号を表現するための書式を規定しています。

[21] HTMLの日付形式は実質的に ISO 8601プロファイルですが、 ISO 8601引用せずに定義されています。 HTML閏秒に対応していないなどの違いもあります。

[186] OGPの日時形式も、 ISO 8601 を基にしています。

[191] AWSISO 8601 形式と称して、 YYYYMMDDThhmmssZ のような記号を使わない形式を用いています >>190

[195] clock (RTSP)

[196] NPT

[187] XMPPの日時形式も、 ISO 8601 から派生したものです。

[358] Modified ISO8601 - ACP_Proposal_Modified_ISO8601.pdf, , https://fhiso.org/wp-content/uploads/gravity_forms/1-f519698841e98c110faf9a3c2f50cd0e/2013/03/ACP_Proposal_Modified_ISO8601.pdf

yyyy-Qqq を [ 1, 4 ] として四半期を表すことを提唱し、 ISO への提案を求めています。

[405] MongoDB Extended JSONにおける日時

[408] Table Schemaの日時

RFC 3339 の ISO 8601 構文#

[203] RFC 3339 は、RFC 3339の日時形式を規定するだけでなく、 ISO 8601:1988ABNF 構文も参考として示しています >>202

[204] RFC 3339ISO 8601 が曖昧であると指摘して、 次のように解釈しています >>202

  • [205] 基本書式拡張書式の混合が認められるか不明なので、 認めることとする。
  • [206] 240 以外となることが認められるか不明なので、 に関わらず認めることとする。
  • [207] 日の数の制約を適用する。
  • [208] T が省略できる場合があるとされているが、 曖昧性を除去するため、必須とする。
  • [209] 小数部があって整数部0 のとき、 0 を省略できないと本文にあり、省略した例示があるが、 本文に従い省略できないこととする。

[211] こうした問題のいくつかは、 ISO 8601 の改訂で解消しています。

その他の応用#

[241] ISO 8601 の応用

[243] ISO 19103の日時形式は、 Date, Time, DateTime など ISO 8601の日時形式を採用したデータ型です。 ISO 19108 など ISO 19100シリーズで使われています。

[269] DSSSLJIS X 4153:1998 8.5.11 は、 「ISO 8601形式の日付又は時刻」 を扱っていました。

[270] ISO 12083: JIS X 0804-1996 p.115 DATE 要素では、 ISO 8601:1988の方式, mm-dd-yy, mm/dd/yy, dd-mm-yy, 月日年 のいずれかの形式を使えるものとし、 他の形式にも拡張できるとしていました。

[271] DCDateISO 8601 のプロファイルを推奨していました。 JIS 版は JIS X 0301 のプロファイルを推奨していました。 その具象構文の一種である RSS 1.0dc:date は、 W3C-DTF とすることを求めていました。 dc:date

[310] RFC 767 - Structured format for transmission of multi-media documents, , https://tools.ietf.org/html/rfc767#page-7

[313] STONの日時形式

[314] ston/ston-paper.md at master · svenvc/ston · GitHub, https://github.com/svenvc/ston/blob/master/ston-paper.md#conventional-representations
  • Time a one element array with an ISO style HH:MM:SS string
  • Date a one element array with an ISO style YYYYMMDD string
  • DateAndTime, TimeStamp a one element array with an ISO style YYYY-MM-DDTHH:MM:SS.N+TZ.TZ string

[317] 「ISO style」が何を意味するか明らかではありませんが、 ISO 8601 のことだとすると、 +TZ.TZ は構文が微妙に違っています。

[315] ston/ston-spec.md at master · svenvc/ston · GitHub, https://github.com/svenvc/ston/blob/master/ston-spec.md#time

Time

Simple time data is represented using a singleton list with a string in ISO style "HH:MM:SS.N" representation (with optional nanoseconds).

Time [ '20:28:41' ]
Time [ '20:28:41.063687' ]

Date

The date object is represented using a singleton list with a string in ISO style "YYYY-MM-DD[+|-]hh:mm" representation (with timezone offset).

Date [ '2018-10-29+01:00' ]

DateAndTime

The timestamp (date and time) object is represented using a singleton list with a string in ISO style "YYYY-MM-DDTHH:MM:SS.N[+|-]" representation (with timezone offset and optional nanoseconds).

DateAndTime [ '2018-10-29T20:30:35+00:00' ]
DateAndTime [ '2018-10-29T20:30:35.899433+01:00' ]

[316] こちらの 「ISO style」 は ISO 8601 の形式。

[323] Sailthruの日時形式ISO 8601 に従うとドキュメントに書いていますが、 ドキュメントがそうでない例ばかり示しています。 Sailthruの日時形式

[328] FITAの日時形式日時基本書式の独自の拡張と、 相対時刻記述のための拡張がなされています。

YYYY-MM-DD (or YYYYMMDD)

[409] XMDF:

[410] Date形式

JIS X 0301の表記方法に従う。"2001-11-10"のよう に省略して表記することも可能。詳細は"http://www.w3.org/TR/NOTE-datetime"を参照。

[411] >>410 JIS X 0301 (ISO 8601) に従うといっているのになぜか W3C-DTF を参照させている。どちらに従うべきなのか。

[412] Time形式

時間を記録するための形式。“XXdXXhXXmXXsXXXms”(Xは0〜9の数字)の形式で記述する。例え ば,“10d5h30m10s015ms”の場合,10日と5時間30分10秒15ミリ秒であることを示す。必要に応じて, “5m30ms”,“1s”などと省略可能。dよりも前の桁数は制限しない。

[413] >>412 これは ISO 8601 ではない独自形式の時間長

各国版#

[234] 他の ISO国際標準と同じように、 各国の国内規格ともなっています。

米国#

[275] 米国連邦政府の情報処理用標準規格 FIPS 4 (Federal Information Processing Standard 4) Calendar Date は、 に制定され、 施行されました。 (施行日以前でも当事者間の合意により実施可能とされました。) >>274

[276] 次のように定めていました。 >>274

[291] グレゴリオ暦と明記されていましたが、 紀年法は明記されていませんでした。

[287] ANSI X3.30-1971 は、 西暦1971年に制定されました。

[288] ANSI X3.30-1985 は、 に制定されました。 ANSI X3.30-1971 を置き換える改訂版でした。 >>285

[289] ANSI X 3.30-1985 は実質的に FIPS PUB 4 と同内容でしたが、 規定はおおむね FIPS より洗練されていました。 次のように定めていました。 >>285

[299] 暦法紀年法も明記されていませんでした。

[286] FIPS PUB 4-1 は、 に制定されました。 FIPS PUB 4 を置き換える改訂版でした。 ANSI X3.30-1985 をそのまま採用したものでした。 >>285

[300] FIPS PUB 4-1 は関連規格として FIPS PUB 58-1, FIPS PUB 59, ANSI X3.30-1985, ANSI X3.43-1986, ANSI X3.51-1975, ISO 2014-1976, ISO 2711-1973, ISO 3307-1975, ISO 4031-1978 を示していました。 ANSI X3.30-1985 以外は言及がなく関係は不明です。

[306] FIPS PUB 4-1 の1991年のものとされる PDFファイルが公開されています。 その内容は ISO 8601:1988ISO 8601:1988/Cor.1:1991 でした。 手書きで 「Related to FIPS 4-1」 と書かれていました。 >>305

[307] これ以上の詳細は不明で、また、以後の改正に関する記述 >>302 には何も言及がありませんでした。

[301] FIPS PUB 4-1 に対して Change Notice 1 がに発行されました >>302

[303] Federal Register Change Notice #2 がに発行されました。 FIPS PUB 4-1 および Change Notice 1 を置き換える改訂版で、 FIPS PUB 4-2 Representation of Calendar Date for Information Interchange となりました。 >>302

[304] Change notice 2 は FIPS PUB 4-1 に編集上の訂正を加えたものとされますが、 2000年問題対策のため改正されたものだといいます。 >>302

[327] 関連: TOPS-10の日時形式

[318] Federal Information Processing Standards Publication: for information systems - representations of local time of day for information interchange - fipspub58-1.pdf, , https://nvlpubs.nist.gov/nistpubs/Legacy/FIPS/fipspub58-1.pdf

JIS X 0301#

[39] ISO 8601JIS 版が JIS X 0301 (旧 JIS C 6262) です。

[326] の9月頃に正誤票が発行されたそうです。 元号一覧

[220] かつては JIS C 6262日付形式のみを定めていました。 時刻形式は別に JIS X 0302 (JIS C 6263) がありました。

[40] JIS X 0301 には ISO 8601 の翻訳に元号を使った日付形式の規定を組み込んでおり、 国際規格との対応の程度は MOD とされています。

[228] 「JIS X 0301 形式」 のような曖昧な言い方をする人がたまにいます。 「ISO 8601 形式」が曖昧なのと同様「JIS X 0301 形式」も曖昧です。 JIS X 0301 固有の元号を使う形式 (これ自体も複数あります。) を指している人もいれば、 ISO 8601 にある形式のいずれかを指している人もいます。

[239] Ruby には jisx0301 メソッドがあり、 元号方式の一種に対応しているようです。

[44] :2002 5.1.3 で、文字に とかを追加してるけど、 4.4 を修正してないのは初歩的なミス。 4.4 は JIS X 0201 で規定する文字を使うといっているが、 とかは 0201 にはない。

[41] JIS X 0301 は 2002年に新版が出たらしいのですが、 JISC Web site からはまだ入手出来ないどころか、旧版も見れない状態が続いています。

[42] >>41 今は :2002 が入手できるようです。

[172] 元号を使う場合、次の接頭辞の後2桁の数字で年号を表記します。

元号コード

[173] また元号を使う場合は年月日の区切りに - ではなく . を使います。

[221] 元号による日付の構文では、 元号を記述するものを拡張形式元号を省略して年月日のみとするものを基本形式としています。 どちらも区切りの . は必要です。

[222] ISO 8601 は区切り記号がないものを基本形式、 あるものを拡張形式と呼んでおり、 JIS X 0301 が拡張した元号方式だけ一貫していません。 杜撰な拡張です。

[223] 「必要によっては」元号を示してもよいと規定されていますが、 元号なしにのみを示すのではが特定できません。 元号を明示するのが基本形であるべきで、 応用分野によって元号が文脈から明確であって従来の慣用などに従い元号を省略することが好ましい場面でのみ省略を許すべきでした。 情報交換目的の規格であるにも関わらず、 情報交換における標準化の意義を理解していない者が開発した規格としか思えません。

[174] 附属書1 (参考) には、明治6年の改暦より前は適用範囲外で、 「換算には特別な注意が必要」との注記があります。 ただしこの表には「M01.01.01」が「1868-01-25」に対応するなど旧暦グレゴリオ暦の対応関係が明治初年から明治5年までも示されています。 規定本体にはそのような規定はありませんが。

[181] 年は2桁とされているので、最新元号の100年とそれ以降も表せないことになります。

[225] 改元の前後の正当な表記ではない元号年月日の組み合わせをどう扱うか (認められるのかどうか、受信した時どう解釈するべきか) には一切言及がありません。もっとも ISO 8601 自体が値域外の値を得た時どう解釈するべきかに言及していません。 附属書1 (参考) には元号の最初と最後の日付の一覧がありますが、 あくまで参考であり、元号を使った日付表現の規定との関係性は不明です。 元号の日付の慣習的解釈に従うなら、 改元を過ぎた旧元号による記述も適当に読み替えて受け入れるべきです。 改元

[184] 改元があった場合、改正されるものと思われます。

[224] 平成改正で追加されたとみられます。 改元から3年も JISC は何をしていたのでしょうか。

[226] こんな具合ですから、世間でほとんど相手にされていないのも当然でしょう。 (JIS X 0301 の規定する元号を使った日付と同じ構文のものは昔からよく使われていますが、 「JIS X 0301 の規定するもの」として使われていることは稀です。) 官公庁システムなどが JIS X 0301 方式を使うと定めている可能性はあります (が元号コード方式など他の方式の方が公表されている仕様書ではよくみられます)。

[227] 主要な実装で JIS X 0301元号日付に対応しているのは Ruby くらいでしょうか。その RubyJIS X 0301改正を待たずに令和に対応したようです。 令和改元

[230] 日本政府改正して JIS X 0301:2019 としました >>231。改正版は既存の JIS X 0301:2002 をそのまま残し、新たに JIS X 0301:2002/AMENDMENT 1:2019 情報交換のためのデータ要素及び交換形式―日付及び時刻の表記(追補1) (Data elements and interchange formats -- Information interchange -- Representation of dates and times (Amendment 1)) を追加する形とされました。

[232] Amd.1:2019 は、既存の元号に関する規定に「令」と「R」 を追加するという最低限の変更のみ行うものでした。

[233] 令和改元では比較的迅速に対応されたといえます。 技術的な変更がなく法令改正への対応のみの形式改正であるとし、 原案委員会を設ける通常の手続きではなく経済産業省が直接原案を作成し JISC 標準第2部会に諮り、承認されました >>235

[238] 月1回の定例スケジュールで新元号発表後最短で改正されたようです。 理論上改元後20日間は新元号を使えない空白期が生じたことになりますが、 ほぼ自明であり特別な手続きを執る必要はないと判断されたのでしょう。 (実際その通りであり、しかも閲覧も面倒な JIS の改正を急ぐよりも Webサイトの Q&A >>237 をタイムリーに更新することにリソースを集中させたのは正しい判断だったと思われます。 正式な JIS よりも公的だけど非正式であろう Web ページの記述の方が有用だというのは、 JIS の存在意義を疑わせるものではありますが...)

[268] なお、 JIS 規格票内での日付表記については、 現代日本の紀年法参照。

[237] 改元に伴う情報システムの改修等を進めていく上でよくご質問いただく事項について (METI/経済産業省) () https://www.meti.go.jp/policy/it_policy/kaigen/faq.html

JIS X 0301(情報交換のためのデータ要素及び交換形式-日付及び時刻の表記)については、改元に伴い、「令和」の表記を定めるなどの改正作業を進めております。

CNS 7648#

[169] 中華民国CNS では、 CNS 7648 (CNS X 0003) が ISO 8601 に対応します。

(日付民国紀元)

[170] 巷では CNS 7648民国紀元の表現についても規定しているとされていて、 R.O.C.74-04-12 のように R.O.C. を使って表記するとされています。

[171] 民国81年改正版の附録A (参考、12ページ) の例示には確かにそのような表記例が示されていました。 しかしなぜか肝心の本文にはまったく言及がありませんでした。

[265] 民国104年改正版にはそのような例示すらありませんでした。

[266] 当初版では民国紀元を使った構文も規定されていたのでしょうか。

[178] 日本語WikipediaCNS 7648民国紀元が 「西暦と共に標準化されている」 >>177 と述べ、 CNS民国紀元を定義していると誤解を招くような説明をしています。 中文版と英語版は CNS民国紀元による表記方法があると述べるにとどまっています。 ただし英語WikipediaROC 93-05-03 という例を示しています >>179中文Wikipedia の例は R.O.C.102-01-01 >>180日本語Wikipedia の例は R.O.C.90-09-11 >>177 で、 「.」が入っていて U+0020 は入りません。

[267] なお、 CNS 規格票内の日付表記については、 CNS 参照。

TIS 1111#

[183] タイでは TIS 1111:2535 >>217 (1992) が ISO 8601 に相当しています。 TIS 1111の日時形式は、 当時の ISO 8601の日時形式とほぼ同じものですが、 西暦4桁または2桁年号のかわりに仏暦4桁または2桁年号を採用しています。

国連#

[331] の第2次規格です >>330。 開発グループは ISO 8601 の制定作業に参加すると共に、 制定に伴い改正しました >>330

[332] の第1次規格は ISO 2014, ISO 2015, ISO 2711, ISO 3307 に基づいていました。 >>330 (いずれも ISO 8601 の前世代に当たり、 ISO 8601 制定によって廃止された規格。)

[333] 現在公開中の第2次規格は、 ISO 8601:1988 と技術的に同等と思われます。 (要検証)

[334] PDF で公開されていますが、週を表す「W」の両側にスペースが入っているのが気になります。 (「T」などには無いのに。)

[335] Wayback Machine, https://web.archive.org/web/20170929000136/http://www.jastpro.org/un/pdf/2014_united_nations_ad_07.pdf

[336] >>335>>330 の日本語訳 (ページ単位の対訳)。

[337] >>335 の翻訳部分は表記面が杜撰で、 原文の「 W 」を「W」にしている箇所があります (「 W 」のままの箇所もあります)。 また PDF のテキストとして (および表示上) 「T」が半角なところと全角なところがあり、 「+」 と 「-」 は符号となるとき全角なのに、区切子の「-」は半角です。

[352] >>351 は翻訳ではないものの、 主要部分の和訳に近い。 採択としか書かれていませんが、 ISO 8601 に言及されているので、 第2次規格を知っているはずです。 (そもそもこの文書の発行が平成10年で既に第2次規格発行後。)

[353] >>351 では「 W」になってます。

[354] >>351 には ISO 8601 由来の T だの / だの P だのといった区切りや時差の記述がありません。

そのかわりに範囲は前後の日時を「ダブルハイフン」でつなげると書かれています。 例えば

時刻の範囲の例なし
年月の単独表記は紹介されておらず、範囲の例の中にだけ出てくる

[355] また時刻には 1975-02-20-1000 のように区切子が存在していません。

[356] これらは第1次規格に由来するのかもしれません。

[357] でも #page=101 には

TRADE/WP.4/INF.1 08;TD/B/FAL/INF.1 08 (October, 1988)

と書かれていて、これは第2次規格を指しているのですよ。

その他#

[218] 中華人民共和国には ISO 8601:2000 と同内容の GB/T 7408-2005 があります。 (その前は GB/T 7408-1994 でした。) >>321 独自の規定は含まれないようです。

[322] 大韓民国には KS X ISO 8601:2010 があります。 独自の規定は含まれないようです。

[359] インドにおいては、旧規格

... が取り下げ (withdraw) されました。 >>360

構文解析#

[8] ISO 8601 は同仕様に適合する日時の構文のみを定めており、 適合しない日時が含まれる可能性がある場合の構文解析や解釈の方法には言及がありません。

[67] また ISO 8601日時の多様な表現方法を認めていますが、 その中には構文上互いに区別できないものもあります。 ISO 8601 としては、 どの表現方法を採用するか事前に情報交換の当事者間の合意があるはずなので問題ないという立場なのでしょう。

[146] HTML は、任意の文字列をどう HTMLの日時形式として解釈するべきかを曖昧無く規定しています。

[166] ISO 8601 の日時形式に基づく各種仕様の中にはエラー処理の方法を一部規定するものもありますが、多くは明確に規定していません。

関連#

[324] 日時に関係して他に ISO 34000, ISO 34002, ISO 34003, ISO 34300 が開発中です。

[414] npt-date

歴史#

ISO 日時標準の制定#

[341] ISO Recommendation R 2014-1971 (ISO/R 2014) が発行されました。 >>339

[349] ISO Recommendation R 2015-1971 (ISO/R 2015) が発行されました。 >>346

[350] 興味深いことに、日本代表は反対票を投じました。 >>346

[342] 以降、 ISO/TC 154ISO/R 2014, ISO/R 2015勧告から国際標準に移行することを決めました。 >>339, >>346

[338] ISO 2014-1976 Writing of calendar dates in all-numeric form Représentation numérique des dates が発行されました。 >>339, >>340

[348] ISO 2015-1976 Numbering of weeks Numérotage des semaines が発行されました。 >>346, >>347

[343] ISO 2014-1976ISO/R 2014-1971 と、 ISO 2015-1976ISO/R 2015-1971 と、 技術的に同等でした。 >>339, >>346

[372] ISO 2711-1973 Information processing interchange - Representation of ordinal datesISO/TC 97 により制定されました。 に賛成多数で承認されていました。 >>371

[378] ISO 3307-1975 Information interchange - Representations of time of the day, Échange d'information - Représentations de l'heureISO/TC 97 により制定されました。 に賛成多数で承認されていました。 >>376, >>377

[393] IS0 4031-1978 Information interchange - Representation of local time differentials, Échange d'information - Représentation des différences d'heure légaleISO/TC 97 により制定されました。 に賛成多数で承認されていました。 >>390, >>392

[373] ISO 2711, ISO 3307, IS0 4031ISO/TC 154 に移管されたことを示す AMENDMENT SLIP が発行されました。 >>371, >>376, >>390

ISO 8601 の制定#

[259] 、 初版 ISO 8601:1988 が制定されました。 ISO/TC 154 により開発されたもので、 ISO 2014:1976, ISO 2015:1976, ISO 2711:1973, ISO 3307:1975, ISO 4031:1978 を廃止し置き換えるものでした。 >>305

[260] 技術訂正票 ISO 8601:1988/Cor.1:1991 が制定されました。 3箇所が訂正されました。 >>305

[261] 西暦2000年に改訂版 ISO 8601:2000 が制定されました。

[262] 西暦2004年に改訂版 ISO 8601:2004 が制定されました。

[229] ISO 8601-1:2019 Date and time -- Representations for information interchange -- Part 1: Basic rulesISO 8601-2:2019 Date and time -- Representations for information interchange -- Part 2: Extensions が出版されました。

ISO 8601-1 は基本的に前の版と同じで、 ISO 8601-2EDTFプロファイルに関する規定など新規の内容でした。

[398] ISO 8601-1:2019/Amd.1:2022 AMENDMENT 1: Technical correctionsISO/TC 154 によって制定されました。 >>399

[400] ISO 8601-1:2019 の一部を改正し、規定や説明を挿入・置換するものです。 >>399

[401] 技術的に大きく変更するものではありませんが、より厳密な規定に改めるものと思われます。 (要検証)

メモ#

時計

[43] Index of ftp://elsie.nci.nih.gov/pub ftp://elsie.nci.nih.gov/pub

[1] 日付および時刻の国際標準表記法 http://www.geocities.co.jp/CollegeLife-Cafe/1646/roomazi/date-time.html: 例のまーくんの、 ISO 8601 推進のための入門的紹介文の翻訳。

[2] >>1 まあさすがに原文がまーくんだけあって中々まーくん風味のまーくん的文章ですね(謎)

[3] >>1−2 なんだかんだ言ってまーくんって英語圏では有名人で影響力ある人だし、 実際 >>1 の原文も英語の技術系 ML とか Web とかでよく参照されてるよねぇ。

[106] ISO 8601:2004 は日時の部分は比較的明確に定義されていますが、時間間隔の部分は参照が多く、 その指示するところが曖昧になっている感じがあります。

[167] OASIS Open Document Format for Office Applications (OpenDocument) Version 1.2 - Part 1: OpenDocument Schema ( 版) http://docs.oasis-open.org/office/v1.2/os/OpenDocument-v1.2-os-part1.html#attribute-number_calendar

gengou: Japanese Gengou calendar, Emperor eras. Identical to Gregorian calendar but with different eras for each emperor. Consumers may implement only the modern eras starting 1868, Meiji, Taisho, Showa and Heisei. Earlier dates are then displayed using the Gregorian calendar [JIS X 0301]

[188] PICS Signed Labels (DSig) 1.0 Specification ( ( 版)) http://www.w3.org/TR/REC-DSig-label/#Reference_Information

[189] REC-PICS-labels-961031 ( ( 版)) http://www.w3.org/TR/REC-PICS-labels-961031#Detailed

[192] 時刻 - Wikipedia ( ()) https://ja.wikipedia.org/wiki/%E6%99%82%E5%88%BB

日付と時刻の表記に関する国際標準規格であるISO 8601では、コロンを用いないのが標準表記であり、拡張表記としてコロンを用いても良いものとされている。

[193] ISO 8601: のない基本書式: のある拡張書式を定義していますが、基本書式が好ましいというニュアンスではないような気が・・・。

[197] Top-level Elements and Attributes (MODS Ver. 3 User Guidelines: Metadata Object Description Schema, Library of Congress) () https://www.loc.gov/standards/mods/userguide/generalapp.html

iso8601 – This value identifies formatted dates allowed in ISO 8601 which use the alternative described as "basic" (i.e., with minimum number of separators) rather than "extended" (i.e., with separators). This alternative specified in the standard uses the following date patterns: YYYY; YYYY-MM if only year and month given; YYYYMMDD if year, month, and day are included (hours, minutes, seconds may also be added: Thhmmss.s). It is also used for other encodings specified in ISO 8601, e.g., date ranges, which are in the form of <date/time>/<date/time>.

<dateIssued encoding="iso8601">20040604T121212</dateIssued>

[198] Upwork API Reference () https://developers.upwork.com/?lang=python#snapshots_get-snapshot

timestamprequired, string

The timestamp either in UTC according to ISO 8601 (yyyymmddTHHMMSSZ) or as a UNIX timestamp (number of seconds after epoch).

[199] PHP: DateTime - Manual () http://php.net/manual/en/class.datetime.php#datetime.constants.iso8601

DateTime::ISO8601

DATE_ISO8601

ISO-8601 (example: 2005-08-15T15:52:01+0000)

Note: This format is not compatible with ISO-8601, but is left this way for backward compatibility reasons. Use DateTime::ATOM or DATE_ATOM for compatibility with ISO-8601 instead.

[200] 注記の通り、 ISO 8601の日時形式を名乗っていますが、実際にはそうではありません。 (基本書式拡張書式が混在していますが、 ISO 8601 では認められていません。)

[201] Draft Agenda – ISO/TC 154/WG 5 – Date and Time – ISO/TC 154 – "Open" Data Interchange () http://www.isotc154.org/isotc-154-2016-anual-meeting-details/isotc154wg5-agenda

[213] DocuSign REST API Guide - Appendix 2: Time Zone and Date/Time Information () https://www.docusign.com/p/RESTAPIGuide/RESTAPIGuide.htm#Appendix/Time Zone and Date-Time Information.htm%3FTocPath%3D_____12

[214] () http://xmlconsortium.org/wg/contact/data/ContactXML_01_01a.pdf

データ型 string (ISO 8601 は必須、または RFC1123)

制限されるデータ値 YYYY-MM-DDThh:mm:ssTZD または YYYY-MM-DD

(例)2001-08-13T19:20:30+09:00

提供側と受領側で合意されている場合に限り、RFC1123 形式を

使用しても構わない。

(例)Wed, 27 Feb 2002 20:28:42 +090

[215] Git - git-commit Documentation () https://git-scm.com/docs/git-commit#git-commit-ISO8601

ISO 8601

Time and date specified by the ISO 8601 standard, for example 2005-04-07T22:13:13. The parser accepts a space instead of the T character as well.

Note

In addition, the date part is accepted in the following formats: YYYY.MM.DD, MM/DD/YYYY and DD.MM.YYYY.

[216] UTS #22: CharMapML () http://www.unicode.org/reports/tr22/tr22-8.html#att_date

The date attribute value must be in ISO 8601 format (yyyy-mm-dd).

[246] Akoma Ntoso Naming Convention Version 1.0 () https://docs.oasis-open.org/legaldocml/akn-nc/v1.0/os/akn-nc-v1.0-os.html#_Toc409028148

  If an approved act, the version date of the Expression in syntax YYYY-MM-DD. For an Akoma Ntoso XML representation, this value MUST correspond to the content of element <FRBRdate> in the <FRBRExpression> section of the metadata. If appropriate, the date can be integrated with a time using values for the XSD:dataTime datatype: Thh:mm:ss±hh:mm. The difference between the local time and Coordinated Universal Time (UTC) is specified using the sign + or - followed by the difference from UTC represented as hh:mm (note: the minutes part is required). See ISO 8601 Date and Time Formats and XML Schema Part 2: Datatypes (http://www.w3.org/TR/xmlschema-2/).

[249] Sending a Request · Product Advertising API 5.0 () https://webservices.amazon.com/paapi5/documentation/sending-request.html

The format must be ISO 8601 basic format (YYYYMMDD'T'HHMMSS'Z').

[252] JIS X 4062:1998 4.2.7 「JIS X 0301 の暦日付完全表記拡張形式」

[272] Linked Data Proofs 1.0 (, ) https://w3c-ccg.github.io/ld-proofs/#proof-algorithm

an [ISO8601] combined date and time string, created, containing the current date and time, accurate to at least one second, in Universal Time Code format

[273] Allow ISO 8601 formatted string for `fast_string_to_time` (kamipo, , ) https://github.com/rails/rails/commit/f870537c4706ef64744958c374fd08243a913543

[311] ニコニコ動画 『スナップショット検索 v2 API』 ガイド () https://site.nicovideo.jp/search-api-docs/snapshot

2021年4月以降、日時のフォーマットが厳格化されます。ISO 8601形式のうち、YYYY-MM-DDThh:mm:ss±hh:mmのフォーマットで指定してください。

[312] 村田真のXMLブログ (, ) http://www.xmlmaster.org/murata/xmlblog/xb090705.html

SC34/WG4コペンハーゲン会議

[406] Xユーザーの伊藤 祐策(パソコンの大先生)さん: 「日付の表記を全世界統一にして欲しい。そんな願いを叶えてるべく作られたのがISO8601なのです...。 しかし!誰も使ってくれないのである!!使ってくれないのである!!!」 / X, , https://twitter.com/ito_yusaku/status/1720064324901962240

[407] >>406 そんな壮大な野望、 ISO 8601 のどこにも書かれていないと思うのだが... 何を根拠にそう言えるのだろうか? 作った人に聞いたのか?