AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / computer / Perguntas / 1524165
Accepted
SimonS
SimonS
Asked: 2020-02-11 02:35:14 +0800 CST2020-02-11 02:35:14 +0800 CST 2020-02-11 02:35:14 +0800 CST

Por que o Excel obtém um resultado diferente do PowerShell e do Google ao tentar descobrir quantos dias se passaram desde 01.01.1900?

  • 772

Um colega me disse: "Exatamente 43871 dias se passaram desde 01.01.1900". Hoje é 10.02.2020.

Eu queria verificar isso com o PowerShell, mas obtive outro resultado:

PS C:\Windows\system32> New-TimeSpan ([datetime]"01.01.1900") (Get-Date)


Days              : 43869
Hours             : 11
Minutes           : 15
Seconds           : 46
Milliseconds      : 304

Fiquei confuso porque havia uma diferença de 2 dias. Então eu perguntei ao Google todo-poderoso:

GoogleDaysPassedSearch

Como você pode ver, o Google também diz que 43869 dias se passaram, não 43871.

Então perguntei ao meu amigo como ele calculava. Ele fez isso no Excel, formatando uma célula para dateonly. Quando ele escreve um intnele, o Excel o converte em uma data, por exemplo

  • 15641torna-se27.10.1942
  • 19874torna-se30.05.1954
  • 43869torna -se 08.02.2020(?)
  • 43871torna -se 10.02.2020(?)

O Excel está 2 dias à nossa frente ou por que acha que houve 2 dias a mais do que realmente houve desde 01.01.1900? Está faltando alguma coisa?

Aqui está um pequeno gif (infelizmente em alemão, já que tenho um Excel em alemão):

ExcelCálculoGif

microsoft-excel date-time
  • 2 2 respostas
  • 325 Views

2 respostas

  • Voted
  1. Best Answer
    Ron Rosenfeld
    2020-02-11T16:47:35+08:002020-02-11T16:47:35+08:00

    O porquê:

    Em primeiro lugar, seu amigo e o Google estão calculando de maneira diferente. O Excel (usando o sistema 1900 Date) considera apenas um dia a mais desde 1900.

    O Excel armazena datas como números de série onde 1-Jan-1900= 1 E 10-Feb-2020-->43871

    Portanto, os dias desde o Excel devem ser 43871- 1->43870

    No entanto, o cálculo do Excel está incorreto.

    Quando o Excel foi introduzido, o Lotus123 era o principal programa de planilhas.

    O Lotus 123 tinha um bug em que pensava que o ano de 1900 era um ano bissexto.

    Para compatibilidade em vista da concorrência, o Excel incluiu esse bug. Porém, como 29-Feb-1900é uma data inexistente, outros métodos irão mostrar, propriamente, 43869ao subtrair as duas datas.

    A propósito, o Excel VBA também calcula a diferença de data corretamente -->43869

    • 4
  2. PeterH
    2020-02-11T07:44:24+08:002020-02-11T07:44:24+08:00

    O Microsoft Excel oferece suporte a dois sistemas de data diferentes. Esses sistemas são o sistema de datas de 1900 e o sistema de datas de 1904.

    O sistema de data de 1900

    No sistema de datas de 1900, o primeiro dia aceito é 1º de janeiro de 1900. Quando você insere uma data, ela é convertida em um número de série que representa o número de dias decorridos começando com 1 para 1º de janeiro de 1900. Por exemplo , se você inserir 5 de julho de 1998, o Excel converterá a data para o número de série 35981. Por padrão, o Microsoft Excel para Windows usa o sistema de data 1900. O sistema de datas de 1900 permite uma melhor compatibilidade entre o Excel e outros programas de planilhas, como o Lotus 1-2-3, projetados para serem executados no MS-DOS ou no Microsoft Windows.

    O sistema de datas de 1904

    No sistema de datas de 1904, o primeiro dia aceito é 1º de janeiro de 1904. Quando você insere uma data, ela é convertida em um número de série que representa o número de dias decorridos desde 1º de janeiro de 1904, começando com 0 para janeiro 1, 1904. Por exemplo, se você inserir 5 de julho de 1998, o Excel converterá a data para o número de série 34519. Devido ao design dos primeiros computadores Macintosh, as datas anteriores a 1º de janeiro de 1904 não eram suportadas. Esse projeto visava evitar problemas relacionados ao fato de 1900 não ser um ano bissexto. No passado, o Excel para Macintosh usava como padrão o sistema de datas de 1904 para pastas de trabalho originadas em um Macintosh. No entanto, o Excel para Macintosh agora é padronizado para o sistema de datas de 1900 e suporta datas a partir de 1º de janeiro de 1900.

    A diferença entre os sistemas de data

    Como os dois sistemas de datas usam dias iniciais diferentes, a mesma data é representada por diferentes números de série em cada sistema de datas. Por exemplo, 5 de julho de 1998 pode ter dois números de série diferentes, como segue.

    Date system          Serial number of July 5, 1998
    1900 date system     35981
    1904 date system     34519
    

    Fonte: https://docs.microsoft.com/en-us/office/troubleshoot/excel/1900-and-1904-date-system

    • 2

relate perguntas

  • Excel Pivot com operador "e"

  • Como usar a função LENGTH do Excel para uma coluna inteira?

  • Matriz do Excel (2 variáveis)

  • como abrir um arquivo de escritório do WSL

  • VBA para renomear planilha com base no nome do arquivo

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Como posso reduzir o consumo do processo `vmmem`?

    • 11 respostas
  • Marko Smith

    Baixar vídeo do Microsoft Stream

    • 4 respostas
  • Marko Smith

    O Google Chrome DevTools falhou ao analisar o SourceMap: chrome-extension

    • 6 respostas
  • Marko Smith

    O visualizador de fotos do Windows não pode ser executado porque não há memória suficiente?

    • 5 respostas
  • Marko Smith

    Como faço para ativar o WindowsXP agora que o suporte acabou?

    • 6 respostas
  • Marko Smith

    Área de trabalho remota congelando intermitentemente

    • 7 respostas
  • Marko Smith

    O que significa ter uma máscara de sub-rede /32?

    • 6 respostas
  • Marko Smith

    Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows?

    • 1 respostas
  • Marko Smith

    O VirtualBox falha ao iniciar com VERR_NEM_VM_CREATE_FAILED

    • 8 respostas
  • Marko Smith

    Os aplicativos não aparecem nas configurações de privacidade da câmera e do microfone no MacBook

    • 5 respostas
  • Martin Hope
    CiaranWelsh Como posso reduzir o consumo do processo `vmmem`? 2020-06-10 02:06:58 +0800 CST
  • Martin Hope
    Jim Pesquisa do Windows 10 não está carregando, mostrando janela em branco 2020-02-06 03:28:26 +0800 CST
  • Martin Hope
    v15 Por que uma conexão de Internet gigabit/s via cabo (coaxial) não oferece velocidades simétricas como fibra? 2020-01-25 08:53:31 +0800 CST
  • Martin Hope
    fixer1234 O "HTTPS Everywhere" ainda é relevante? 2019-10-27 18:06:25 +0800 CST
  • Martin Hope
    andre_ss6 Área de trabalho remota congelando intermitentemente 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney Por que colocar um ponto após o URL remove as informações de login? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    jonsca Todos os meus complementos do Firefox foram desativados repentinamente, como posso reativá-los? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK É possível criar um código QR usando texto? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 Altere o nome da ramificação padrão do git init 2019-04-01 06:16:56 +0800 CST

Hot tag

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve