1900年のExcelの平日が間違っているのはなぜですか?

Jeroen Wiert Pluimers

この質問はの観察に基づいているAdamV彼の答え私はExcelのセルに曜日名を取得するにはどうすればよいですか?

A1の値が2009-08-01の場合、次のようになります。

  • =WEEKDAY(A1) 取得します 7
  • =TEXT(7, "dddd") 取得します Saturday
  • =TEXT(7,"dddd, yyyy-mm-dd") 取得します Saturday, 1900-01-07
  • =TEXT(1,"dddd, yyyy-mm-dd") 取得します Sunday, 1900-01-01
  • =TEXT("1900-01-01","dddd, yyyy-mm-dd") また取得します Sunday, 1900-01-01

最後の2つは間違っています。1900年1月1日は実際には月曜日です。
さまざまな情報源が次のことを確認しているようです。

何が足りないのですか?Excelがこれを間違っているのはなぜですか?

user1686

Microsoft KB 214058で説明されているように

1900年3月1日より前の曜日がExcelで正しくない

詳しくは

Microsoft Excelの日付システムが最初に作成されたとき、他のスプレッドシートプログラムで使用されている日付システムと完全に互換性があるように設計されていました。

ただし、この日付システムでは、1900年はうるう年として誤って解釈されます。1900年には2月29日(「うるう日」)がないため、1900年3月1日(「うるう日」の翌日)より前の日付の曜日は正しく計算されません。

「その他のスプレッドシートプログラム」は、当時非常に人気があったLotus 1-2-3を指し、1900年がうるう年であると誤って想定していました。これについては、KB214326でさらに詳しく説明されています

Excel 2000は、1900年がうるう年であると誤って想定しています。

詳しくは

Lotus 1-2-3が最初にリリースされたとき、プログラムは1900年がうるう年であると想定していましたが、実際にはうるう年ではありませんでした。これにより、プログラムがうるう年を処理しやすくなり、Lotus1-2-3のほとんどすべての日付計算に害を及ぼすことはありませんでした。

MicrosoftMultiplanとMicrosoftExcelがリリースされたとき、彼らは1900年がうるう年であると想定していました。この仮定により、MicrosoftMultiplanとMicrosoftExcelは、Lotus 1-2-3で使用されているものと同じシリアル日付システムを使用し、Lotus1-2-3との互換性を高めることができました。1900年をうるう年として扱うことで、ユーザーはワークシートをあるプログラムから別のプログラムに簡単に移動できるようになりました。

この動作を修正して、現在のバージョンのMicrosoft Excelが1900年がうるう年であると想定しないようにすることは技術的には可能ですが、そうすることの欠点は利点を上回ります。

この動作を修正すると、次のような多くの問題が発生します。

  • 現在のMicrosoftExcelワークシートおよびその他のドキュメントのほぼすべての日付が1日短縮されます。このシフトを修正するには、特に日付を使用する数式では、かなりの時間と労力がかかります。
  • WEEKDAY関数などの一部の関数は、異なる値を返します。これにより、ワークシートの数式が正しく機能しない可能性があります。
  • この動作を修正すると、MicrosoftExcelと日付を使用する他のプログラムとの間のシリアル日付の互換性が失われます。

動作が修正されないままの場合、発生する問題は1つだけです。

  • WEEKDAY関数は、1900年3月1日より前の日付に対して誤った値を返します。ほとんどのユーザーは1900年3月1日より前の日付を使用しないため、この問題はまれです。

この記事はインターネットから収集されたものであり、転載の際にはソースを示してください。

侵害の場合は、連絡してください[email protected]

編集
0

コメントを追加

0

関連記事

分類Dev

「zzz」-le「~~~」が間違っているのはなぜですか?

分類Dev

["text"] == ["text"]が間違っているのはなぜですか?

分類Dev

x <= xが間違っているのはなぜですか?

分類Dev

XOR出力が間違っているのはなぜですか

分類Dev

b [2]が間違っているのはなぜですか?

分類Dev

出力が間違ったUnicodeになっているのはなぜですか?

分類Dev

この単一の出力が間違っているのはなぜですか?

分類Dev

この単一の出力が間違っているのはなぜですか?

分類Dev

私のAngleMathはなぜ間違っているのですか?

分類Dev

長方形が間違って描かれているのはなぜですか?

分類Dev

長方形が間違って描かれているのはなぜですか?

分類Dev

`i`整数の値が間違っているのはなぜですか?

分類Dev

敵の動きが間違っているのはなぜですか?

分類Dev

JPanelのサイズが間違っているのはなぜですか?

分類Dev

次のPythonコードが間違っているのはなぜですか?

分類Dev

このクエリが間違っているのはなぜですか?

分類Dev

SortBy Valuesの結果が間違っているのはなぜですか?

分類Dev

なぜ1 === 1 === 1が間違っているのですか?

分類Dev

CSSなぜ幅が間違っているのですか?

分類Dev

「while(!feof(file))」が常に間違っているのはなぜですか?

分類Dev

リダイレクトが間違っているのはなぜですか?

分類Dev

印刷した日付が間違っているのはなぜですか?

分類Dev

`sudo cat / tmp / 1> file`が間違っているのはなぜですか?

分類Dev

角度コードが間違っているのはなぜですか?

分類Dev

`9.3 == 9.3.to_d`が間違っているのはなぜですか?

分類Dev

SIGNALがDjangoで機能しないのはなぜですか?何が間違っているのですか?

分類Dev

sudoがパスワードが間違っていると言っているのはなぜですか?

分類Dev

この単純な例で私の背景が間違って配置されているのはなぜですか

分類Dev

新しいSimpleDateFormatオブジェクトに間違った年のカレンダーが含まれているのはなぜですか?

Related 関連記事

  1. 1

    「zzz」-le「~~~」が間違っているのはなぜですか?

  2. 2

    ["text"] == ["text"]が間違っているのはなぜですか?

  3. 3

    x <= xが間違っているのはなぜですか?

  4. 4

    XOR出力が間違っているのはなぜですか

  5. 5

    b [2]が間違っているのはなぜですか?

  6. 6

    出力が間違ったUnicodeになっているのはなぜですか?

  7. 7

    この単一の出力が間違っているのはなぜですか?

  8. 8

    この単一の出力が間違っているのはなぜですか?

  9. 9

    私のAngleMathはなぜ間違っているのですか?

  10. 10

    長方形が間違って描かれているのはなぜですか?

  11. 11

    長方形が間違って描かれているのはなぜですか?

  12. 12

    `i`整数の値が間違っているのはなぜですか?

  13. 13

    敵の動きが間違っているのはなぜですか?

  14. 14

    JPanelのサイズが間違っているのはなぜですか?

  15. 15

    次のPythonコードが間違っているのはなぜですか?

  16. 16

    このクエリが間違っているのはなぜですか?

  17. 17

    SortBy Valuesの結果が間違っているのはなぜですか?

  18. 18

    なぜ1 === 1 === 1が間違っているのですか?

  19. 19

    CSSなぜ幅が間違っているのですか?

  20. 20

    「while(!feof(file))」が常に間違っているのはなぜですか?

  21. 21

    リダイレクトが間違っているのはなぜですか?

  22. 22

    印刷した日付が間違っているのはなぜですか?

  23. 23

    `sudo cat / tmp / 1> file`が間違っているのはなぜですか?

  24. 24

    角度コードが間違っているのはなぜですか?

  25. 25

    `9.3 == 9.3.to_d`が間違っているのはなぜですか?

  26. 26

    SIGNALがDjangoで機能しないのはなぜですか?何が間違っているのですか?

  27. 27

    sudoがパスワードが間違っていると言っているのはなぜですか?

  28. 28

    この単純な例で私の背景が間違って配置されているのはなぜですか

  29. 29

    新しいSimpleDateFormatオブジェクトに間違った年のカレンダーが含まれているのはなぜですか?

ホットタグ

アーカイブ