计算房间在指定日期范围内的动态总价:支持按日期覆盖价格与默认价回退
技术百科
花韻仙語
发布时间:2026-01-21
浏览: 次 本文详解如何为多个房间批量计算指定日期列表的总价格——对每个房间,遍历所选日期,优先匹配 `options` 中的特例价格,未命中则使用 `default_price`,最终汇总各房间总价。
在酒店预订、民宿系统或活动场地管理系统中,常需根据用户选择的连续日期(如入住/离店区间),动态计算不同房型的总费用。该场景的核心逻辑是:每个房间拥有一个基础价格(default_price)和一组可选的日期覆盖规则(options 数组),当某天存在特例价格时,应优先采用;否则回落至默认价。关键挑战在于避免状态污染(如累加变量未重置)、确保日期比对精确,并保持代码可读与可维护。
以下是一个健壮、无副作用的实现方案(基于 PHP 8.0+,兼容 Laravel 的 Carbon 可选,但本例使用纯字符串比对以提升性能):
$selectedDates = ['10-04-2025', '11-04-2025', '12-04-2025'];
$setRooms = [
[
'id' => 1,
'title' => 'Room1',
'default_price' => 50,
'options' => [
['date' => '12-04-2025', 'price' => 100],
['date' => '13-04-2025', 'price' => 200],
['date' => '14-04-2025', 'price' => 200],
]
],
[
'id' => 2,
'title' => 'Room2',
'default_price' => 120,
'options' => [
['date' => '11-04-2025', 'price' => 200],
['date' => '12-04-2025', 'price' => 300],
['date' => '13-04-2025', 'price' => 400],
]
],
];
$result = [];
foreach ($setRooms as $room) {
$total = 0;
foreach ($selectedDates as $date) {
// 使用 array_filter 精确查找匹配日期项(注意:日期格式必须完全一致)
$matchedOptions = array_filter($room['options'], fn($opt) => $opt['date'] === $date);
if (!empty($matchedOptions)) {
// 安全获取首个匹配项(因日期唯一,array_key_first 更高效)
$firstKey = key($matchedOptions);
$total += $matchedOptions[$firstKey]['price'];
} else {
$total += $room['default_price'];
}
}
$result[] = [
'id' => $room['id'],
'title' => $room['title'],
'total_price' => $total
];
}
print_r($result);✅ 输出结果验证:
- Room1:10-04-2025 → 50(默认)、11-04-2025 → 50(默认)、12-04-2025 → 100(覆盖)→ 总计 200
- Room2:10-04-2025 → 120(默认)、11-04-2025 → 200(覆盖)、12-04-2025 → 300(覆盖)→ 总计 620
⚠️ 关键注意事项:
-
日期格式一致性:$selectedDates 与 options.da
te 必须严格统一为 'd-m-Y' 格式(如 '10-04-2025'),避免因 Carbon::parse() 隐式转换导致意外匹配失败;
- 避免变量复用陷阱:原问题中 $price 在外层循环未重置,导致累加污染。本方案将 $total 声明于内层循环前,确保每房间独立计算;
- 性能优化建议:若 options 数量庞大(>100 条),可预先构建 date => price 的哈希映射($priceMap = array_column($room['options'], 'price', 'date')),将单次查找从 O(n) 降至 O(1);
- 扩展性提示:如需支持日期范围(而非单日)、多币种或税费叠加,建议封装为独立服务类,遵循单一职责原则。
此方案简洁、可靠、易于测试,可直接集成至 Laravel 控制器、API 服务或后台批处理任务中。
# 是一个
# 可选
# 多个
# 管理系统
# 而非
# 如需
# 性能优化
# 可直接
# 币种
# 循环
# 隐式转换
# 字符串
# 封装
# php
# 比对
# 遍历
# laravel
# date
# 批处理
# carbon
# 币
相关栏目:
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
AI推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
SEO优化<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
技术百科<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
谷歌推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
百度推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
网络营销<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
案例网站<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
精选文章<?muma echo $count; ?>
】
相关推荐
- 如何使用Golang读取日志文件_Golang b
- 如何用::实现单例模式_php静态方法与作用域操作
- Python列表推导式与字典推导式教程_简化代码高
- Windows 10怎么隐藏特定更新补丁_Wind
- Mac如何调整Dock栏大小和位置_Mac程序坞个
- 如何用正则与预处理高效拦截带干扰符的恶意域名
- Python脚本参数接收_sys与argparse
- mac怎么分屏_MAC双屏显示与分屏操作技巧【指南
- Win11怎么关闭自动调节亮度 Win11禁用内容
- C#如何在一个XML文件中查找并替换文本内容
- Python如何创建带属性的XML节点
- Python函数缓存机制_lru_cache解析【
- c++ nullptr与NULL区别_c++11空
- Win11怎么设置声音输出设备_Windows11
- 如何使用Golang实现多重错误处理_Golang
- Win11怎么用设置清理回收站_Win11设置清理
- Go 中实现 Python urllib.quot
- 如何在Golang中引入测试模块_Golang测试
- Win11鼠标灵敏度怎么调 Win11鼠标指针移动
- windows如何修改文件默认打开方式_windo
- 如何使用Golang构建基础消息队列模拟_Gola
- 小程序里php怎么变mp4_小程序调用php生成m
- php8.4xdebug无法调试怎么办_php8.
- 企业SEO优化选择网站建设模板的技巧
- mac怎么打开终端_MAC终端Terminal使用
- php8.4如何调用com组件_php8.4win
- Python函数接口文档化_自动化说明【指导】
- C#怎么创建控制台应用 C# Console Ap
- Win11怎么关闭通知中心_Windows11系统
- 如何使用Golang操作指针变量_Golang解引
- 如何在Mac上搭建Golang开发环境_使用Hom
- Win11开机速度慢怎么优化_Win11系统启动加
- Win11关机界面怎么改_Win11自定义关机画面
- Win11怎么更改系统语言为中文_Windows1
- Win11相机打不开提示错误怎么修_相机权限开启与
- Win11任务栏天气怎么关闭 Win11隐藏天气小
- Python文件操作优化_大文件与流处理解析【教程
- Windows10怎样设置家长控制_Windows
- PHP的Workerman对架构扩展有啥帮助_应用
- Win10电脑怎么设置休眠快捷键_Windows1
- Python字符串操作教程_切片拼接与格式化详解
- Win11怎么设置按流量计费_Win11限制后台流
- Win11怎么查看激活状态_查询Windows 1
- C++中的std::shared_from_thi
- Win11 explorer.exe频繁崩溃_修复
- 如何使用Golang开发基础文件下载功能_Gola
- Win10如何备份驱动程序_Win10驱动备份步骤
- Win11怎么恢复误删照片_Win11数据恢复工具
- Win10电脑怎么设置网络名称_Windows10
- 如何在 Laravel 中通过嵌套关联关系进行 o


QQ客服