统计日期列表中的天数、周末数与月份数(首日计数)
发布时间 - 2025-12-27 00:00:00 点击率:次本文介绍如何基于 iso 格式日期字符串数组,高效统计总天数、周末天数(周六/周日)及跨月次数(以每月1号为标识),提供三种渐进式 javascript 实现方案,兼顾可读性与简洁性。
在处理时间序列数据(如日志记录、用户活跃日、事件调度等)时,常需从日期列表中快速提取基础统计维度:总天数、周末天数(Saturday/Sunday)、以及涉及的月份数。注意:此处“月份数”并非指日期覆盖多少个自然月(如 2025-01-30 至 2025-03-05 跨3个月),而是指列表中有多少个日期是当月的第一天(即 date.getDate() === 1),这在统计“新月启动事件”或“月初操作频次”等场景中非常实用。
以下是三种推荐实现方式,按可读性到简洁性递进:
✅ 方案一:清晰易懂的 forEach 遍历(推荐初学者)
const dateList = [ "2025-01-31T23:00:00.000Z", "2025-02-01T23:00:00.000Z", "2025-02-02T23:00:00.000Z", "2025-02-03T23:00:00.000Z" ]; let dayCount = 0; let weekendCount = 0; let monthCount = 0; dateList.forEach(dateStr => { const date = new Date(dateStr); dayCount++; // 周末判断:getDay() 返回 0(周日) 或 6(周六) if (date.getDay() === 0 || date.getDay() === 6) { weekendCount++; } // 月初判断:日期为当月第1天 if (date.getDate() === 1) { monthCount++; } }); console.log({ day: dayCount, weekend: weekendCount, month: monthCount }); // 输出示例:{ day: 4, weekend: 1, month: 1 }
✅ 方案二:函数式风格 —— 使用 filter(推荐中高级开发者)
更符合函数式编程习惯,逻辑分离清晰,便于单元测试与复用:
const dateList = [/* 同上 */];
const dayCount = dateList.length;
const weekendCount = dateList.filter(str => {
const d = new Date(str);
return d.getDay() === 0 || d.getDay() === 6;
}).length;
const monthCount = dateList.filter(str => new Date(str).getDate() === 1).length;
console.log({ day: dayCount, weekend: weekendCount, month: monthCount });✅ 方案三:极简一行式(慎用于生产环境)
利用取模技巧简化周末判断(getDay() % 6 === 0 等价于 0 或 6),代码紧凑但可读性下降,仅建议在性能敏感且团队熟悉该写法时使用:
const dateList = [/* 同上 */];
const dayCount = dateList.length;
const weekendCount = dateList.filter(s => new Date(s).getDay() % 6 === 0).length;
const monthCount = dateList.filter(s => new Date(s).getDate() === 1).length;
console.log({ day: dayCount, weekend: weekendCount, month: monthCount });⚠️ 注意事项
- 时区安全:输入为 UTC 时间戳(含 Z),new Date() 在浏览器中会自动转为本地时区解析。若需严格按 UTC 计算(如服务端 Node.js),建议使用 Date.UTC() 或专用库(如 date-fns / dayjs)避免歧义。
- 无效日期防护:实际项目中应添加 isNaN(date.getTime()) 校验,防止非法字符串导致 NaN 日期干扰统计。
- “月份”语义澄清:本方案统计的是「列表中作为每月1号出现的日期数量」,而非时间跨度涵盖的月份数。如需后者(例如计算日期范围横跨几个月),应改用 new Date().getFullYear() 与 getMonth() 组合去重统计。
通过以上任一方案,你都能将原始日期数组转化为结构化统计对象 { day, weekend, month },为后续数据分析或可视化提供坚实基础。
# javascript
# java
# js
# node.js
# node
# 浏览器
# 字符串数组
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
EditPlus中的正则表达式 实战(1)
西安专业网站制作公司有哪些,陕西省建行官方网站?
🚀拖拽式CMS建站能否实现高效与个性化并存?
Windows10电脑怎么设置虚拟光驱_Win10右键装载ISO镜像文件
如何在IIS中新建站点并解决端口绑定冲突?
公司网站制作价格怎么算,公司办个官网需要多少钱?
简历没回改:利用AI润色让你的文字更专业
如何正确下载安装西数主机建站助手?
Edge浏览器提示“由你的组织管理”怎么解决_去除浏览器托管提示【修复】
Laravel如何实现多级无限分类_Laravel递归模型关联与树状数据输出【方法】
如何在Ubuntu系统下快速搭建WordPress个人网站?
Laravel如何使用API Resources格式化JSON响应_Laravel数据资源封装与格式化输出
网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?
家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?
智能起名网站制作软件有哪些,制作logo的软件?
Laravel Vite是做什么的_Laravel前端资源打包工具Vite配置与使用
佐糖AI抠图怎样调整抠图精度_佐糖AI精度调整与放大细化操作【攻略】
Laravel如何配置和使用缓存?(Redis代码示例)
如何用PHP快速搭建CMS系统?
网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?
Laravel 419 page expired怎么解决_Laravel CSRF令牌过期处理
Laravel如何使用软删除(Soft Deletes)功能_Eloquent软删除与数据恢复方法
Laravel集合Collection怎么用_Laravel集合常用函数详解
Mybatis 中的insertOrUpdate操作
活动邀请函制作网站有哪些,活动邀请函文案?
Claude怎样写约束型提示词_Claude约束提示词写法【教程】
Python面向对象测试方法_mock解析【教程】
宙斯浏览器文件分类查看教程 快速筛选视频文档与图片方法
通义万相免费版怎么用_通义万相免费版使用方法详细指南【教程】
如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?
香港服务器WordPress建站指南:SEO优化与高效部署策略
网站图片在线制作软件,怎么在图片上做链接?
Laravel如何发送系统通知?(Notification渠道示例)
javascript中对象的定义、使用以及对象和原型链操作小结
Linux系统命令中tree命令详解
Laravel怎么创建控制器Controller_Laravel路由绑定与控制器逻辑编写【指南】
JavaScript数据类型有哪些_如何准确判断一个变量的类型
大连网站制作公司哪家好一点,大连买房网站哪个好?
Laravel如何优化应用性能?(缓存和优化命令)
Laravel队列由Redis驱动怎么配置_Laravel Redis队列使用教程
LinuxCD持续部署教程_自动发布与回滚机制
黑客如何利用漏洞与弱口令入侵网站服务器?
Swift中循环语句中的转移语句 break 和 continue
Windows10如何删除恢复分区_Win10 Diskpart命令强制删除分区
Windows11怎样设置电源计划_Windows11电源计划调整攻略【指南】
javascript读取文本节点方法小结
Python自然语言搜索引擎项目教程_倒排索引查询优化案例
JavaScript中的标签模板是什么_它如何扩展字符串功能
Laravel Eloquent关联是什么_Laravel模型一对一与一对多关系精讲
Gemini怎么用新功能实时问答_Gemini实时问答使用【步骤】


ount = 0;
let weekendCount = 0;
let monthCount = 0;
dateList.forEach(dateStr => {
const date = new Date(dateStr);
dayCount++;
// 周末判断:getDay() 返回 0(周日) 或 6(周六)
if (date.getDay() === 0 || date.getDay() === 6) {
weekendCount++;
}
// 月初判断:日期为当月第1天
if (date.getDate() === 1) {
monthCount++;
}
});
console.log({
day: dayCount,
weekend: weekendCount,
month: monthCount
});
// 输出示例:{ day: 4, weekend: 1, month: 1 }