当前位置: 首页 > news >正文

Ruby 之交租阶段信息生成

题目

我看了一下,这个题目应该不是什么机密,所以先放上来了。大概意思是根据合同信息生成交租阶段信息。

解答

要求是要使用 Ruby 生成交租阶段信息,由于时间比较仓促,变量名那些就用得随意了些。要点主要有下面这些:

  • 第一个交费阶段是要单独算
  • 整月和非整月的计算方式是不一样的(同样的整月,不同月的天数不一样,但是租金还是要算成一样的,我目前是把合同起始结束月都当做非整月来算)
  • 循环结束时间判断(其实也就是缴费阶段结束日期和合同的结束日期进行对比判断)
require 'time'
require 'terminal-table'class Rentdef initialize(contract_start, contract_end, month_rent, cycle)@contract_start = Time.strptime(contract_start, "%Y-%m-%d").to_date@contract_end = Time.strptime(contract_end, "%Y-%m-%d").to_date@month_rent = month_rent@cycle = cycle@year_total_rent = 12 * month_rent.to_f@tb = Terminal::Table.newenddef generate_next_month_last_day(time)date = Date.new(time.year, time.month, time.day)date = date.next_monthDate.civil(date.year, date.month, -1)enddef calculate_first_month_rent(time)month_last_day = Date.civil(time.year, time.month, -1)month_day_left = month_last_day.day - time.day + 1@year_total_rent * month_day_left / 365enddef calculate_last_month_rent(time)@year_total_rent * time.day / 365enddef add_rows# 合同起始和结束日期当月都按非整月计算,其他整月按整月的租金计算rent_day = @contract_starttotal = calculate_first_month_rent(@contract_start)to_end = falsetmp_cycle = @cycle - 1next_month_last_day = rent_dayif tmp_cycle == 0 # 一月一租next_month_last_day = Date.civil(next_month_last_day.year, next_month_last_day.month, -1)enduntil tmp_cycle == 0next_month_last_day = generate_next_month_last_day(next_month_last_day)if next_month_last_day > @contract_endtotal += calculate_last_month_rent(@contract_end)next_month_last_day = @contract_endto_end = truebreakendtotal += @month_renttmp_cycle -= 1endstart_date = rent_dayend_date = next_month_last_day@tb.add_row([start_date, end_date, rent_day, "%.2f" % total])total = 0until to_endtmp_cycle = @cyclerent_day = Date.new(next_month_last_day.year, next_month_last_day.month, 15)start_date = next_month_last_day + 1until tmp_cycle == 0next_month_last_day = generate_next_month_last_day(next_month_last_day)if next_month_last_day > @contract_endtotal += calculate_last_month_rent(@contract_end)next_month_last_day = @contract_endto_end = truebreakendtotal += @month_renttmp_cycle -= 1endend_date = next_month_last_day@tb.add_row([start_date, end_date, rent_day, "%.2f" % total])total = 0endenddef show_tableset_table_titleset_table_headingsadd_rowsprint_tableenddef set_table_title@tb.title = "交租阶段信息"enddef set_table_headings@tb.headings = ["开始日期", "结束日期", "交租日期", "交租阶段总租金"]enddef set_align_column@tb.number_of_columns.times do |index|@tb.align_column(index + 1, :right)end@tb.align_column(0, :left)enddef print_tableputs @tbputsend
endrent = Rent.new("2020-11-16", "2021-03-16", 5000, 2)
rent.show_table
+------------+------------+------------+----------------+
|                     交租阶段信息                      |
+------------+------------+------------+----------------+
| 开始日期   | 结束日期   | 交租日期   | 交租阶段总租金 |
+------------+------------+------------+----------------+
| 2020-11-16 | 2020-12-31 | 2020-11-16 | 7465.75        |
| 2021-01-01 | 2021-02-28 | 2020-12-15 | 10000.00       |
| 2021-03-01 | 2021-03-16 | 2021-02-15 | 2630.14        |
+------------+------------+------------+----------------+

目前按照一月一交的话,交租日期那块显示还有点问题,这个后面再优化吧。

+------------+------------+------------+----------------+
|                     交租阶段信息                      |
+------------+------------+------------+----------------+
| 开始日期   | 结束日期   | 交租日期   | 交租阶段总租金 |
+------------+------------+------------+----------------+
| 2020-11-16 | 2020-11-30 | 2020-11-16 | 2465.75        |
| 2020-12-01 | 2020-12-31 | 2020-11-15 | 5000.00        |
| 2021-01-01 | 2021-01-31 | 2020-12-15 | 5000.00        |
| 2021-02-01 | 2021-02-28 | 2021-01-15 | 5000.00        |
| 2021-03-01 | 2021-03-16 | 2021-02-15 | 2630.14        |
+------------+------------+------------+----------------+
http://www.lryc.cn/news/332954.html

相关文章:

  • RUST语言值所有权之内存复制与移动
  • 【Django学习笔记(三)】BootStrap介绍
  • ClickHouse开发相关(UDAF)
  • MySql并发事务问题
  • Windows下Docker创建Mysql5.7
  • Redis(性能管理、主从复制、哨兵模式)概述及部署
  • LabVIEW挖坑指南
  • docker容器环境安装记录(MAC M1)(完善中)
  • Linux 常用命令(持续更新中...)
  • xss.pwnfunction-Jefff
  • java——文件上传
  • RCE(远程命令执行)漏洞详解
  • K8S - Deployment 的版本回滚
  • 53 v-bind 和 v-model 的实现和区别
  • VMware-16.0配置虚拟机网络模式
  • element-ui badge 组件源码分享
  • MySQL中日期有关函数
  • jdbc工具类
  • Svelte Web 框架介绍
  • IP地址获取不到的原因是什么?
  • Android APP加固利器:深入了解混淆算法与混淆配置
  • 蓝桥杯真题Day47 倒计时6天:6道真题+回溯递归问题
  • 通过UDP实现参数配置
  • 解析Apache Kafka:在大数据体系中的基本概念和核心组件
  • 独角数卡对接码支付收款教程
  • vuepress-theme-hope 添加谷歌统计代码
  • LabVIEW太赫兹波扫描成像系统
  • 什么是stable diffusion?
  • KeyguardClockSwitch的父类
  • Gradle系列(二):Groovy基础