excel中的时间格式通过js转化为正常时间

在JavaScript中,如果有一个类似44419.40592592592这样的数字,它通常不代表直接可用于Date对象的格式,因为JavaScript的Date对象期望的是从1970年1月1日UTC开始的毫秒数(时间戳)。

但是,如果知道这个数字是基于某个特定的起点(比如Excel中的1900年1月1日或1904年1月1日,因为Excel有一个关于1900年是否为闰年的错误),可以通过计算将其转换为JavaScript中的Date对象。

然而,由于44419.40592592592看起来更像是从某个日期开始的天数加上一天中的时间比例,我们可以假设它是从某个特定日期(比如Excel的基准日期)开始的。但在这个例子中,我将使用1900年1月1日作为起点(尽管这不是Excel的默认行为,因为Excel实际上在日期计算上有其复杂性,特别是关于1900年的处理)。

注意:以下示例仅用于说明如何将这种格式转换为JavaScript日期,并且它假设了一个不常见的起点(1900年1月1日)。在实际应用中,可能需要调整这个起点。

javascript 复制代码
function convertToJSDate(daysSinceEpoch, epochYear = 1900) {  
    // 创建一个从epochYear年1月1日开始的日期  
    const epochDate = new Date(epochYear, 0, 1); // 月份从0开始计数,所以0代表1月  
  
    // 计算总毫秒数  
    // 一天有 24 * 60 * 60 * 1000 毫秒  
    // daysSinceEpoch的整数部分是天数,小数部分是当天的时间比例  
    const totalMilliseconds = daysSinceEpoch * 24 * 60 * 60 * 1000;  
    const dayMilliseconds = Math.floor(daysSinceEpoch) * 24 * 60 * 60 * 1000;  
    const timeFraction = daysSinceEpoch - Math.floor(daysSinceEpoch);  
    const timeMilliseconds = timeFraction * 24 * 60 * 60 * 1000;  
  
    // 使用epochDate和计算出的毫秒数来创建新的日期对象  
    const resultDate = new Date(epochDate.getTime() + dayMilliseconds + timeMilliseconds);  
  
    return resultDate;  
}  
  
// 使用示例  
const days = 44419.40592592592;  
const convertedDate = convertToJSDate(days, 1900); // 注意:这里使用1900年作为起点可能不是最佳选择  
console.log(convertedDate.toISOString()); // 这将输出一个ISO格式的日期字符串  
相关推荐
岱宗夫up2 分钟前
Python 数据分析入门
开发语言·python·数据分析
码界筑梦坊4 分钟前
325-基于Python的校园卡消费行为数据可视化分析系统
开发语言·python·信息可视化·django·毕业设计
多恩Stone7 分钟前
【RoPE】Flux 中的 Image Tokenization
开发语言·人工智能·python
李日灐9 分钟前
C++进阶必备:红黑树从 0 到 1: 手撕底层,带你搞懂平衡二叉树的平衡逻辑与黑高检验
开发语言·数据结构·c++·后端·面试·红黑树·自平衡二叉搜索树
John_ToDebug10 分钟前
引擎深处的漫游者:构建浏览器JavaScript引擎的哲学与技艺
javascript·chrome·js
Risehuxyc18 分钟前
备份三个PHP程序
android·开发语言·php
lly20240624 分钟前
PHP Error: 常见错误及其解决方法
开发语言
网安墨雨25 分钟前
Python自动化一------pytes与allure结合生成测试报告
开发语言·自动化测试·软件测试·python·职场和发展·自动化
程序猿阿伟25 分钟前
《TypeScript中Protobuf到运行时类型安全的转换指南》
javascript·安全·typescript
毕设源码李师姐27 分钟前
计算机毕设 java 基于 java 的图书馆借阅系统 智能图书馆借阅综合管理平台 基于 Java 的图书借阅与信息管理系统
java·开发语言·课程设计