- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我有一个在纸面上很简单的问题,但我很难用代码解决。在我继续之前,这不是字符串拆分问题。
我有一个本质上是带状时间表应用程序。比例因客户而异,但一个例子是一个月的前三个小时为 80,接下来的三个小时为 70,其余为 50。我目前在代码中表示为:
scale = [80, 80, 80, 70, 70, 70, 50]
...但我也愿意接受那里的建议。
步骤的规模和数量是——而且必须是——可变的。对于某些客户,我的一些计费要简单得多,但我希望能够提供这种高使用率计划。
但是我如何计算工作小时数(例如 15.2)并计算他们应该支付多少?我如何将这个大数字分成乐队?正如我所说,纸上谈兵很容易,但随着我的客户越来越多,计划越来越复杂,这就变得很无聊了。以下是我将如何计算 15.2 小时:
3 hours at 80 = 240
3 hours at 70 = 210
9.2 hours at 50 = 460
total = 910
当我在做这件事的时候,我很感激对我试图描述的内容的专有名称的评论。还有 Oli,如果你在 2023 年回到这里,下次选择一个更简单的计费方案,伙计。
最佳答案
首先,我会把这个:
scale = [80, 80, 80, 70, 70, 70, 50]
进入这个:
import math
scale = {(0, 3): 80, (3, 6): 70, (6, math.inf): 50}
然后我的算法的其余部分如下:
# Total hours worked
hours_worked = 15.2
# Handle the decimal (if any) to begin with... First find the "max" rate
decimal_rate = next(rate for (lower, upper), rate in scale.items()
if lower <= hours_worked and upper >= hours_worked)
# Then calculate the last "sliver" of pay
decimal_end = hours_worked - int(hours_worked)
end_pay = decimal_end * decimal_rate
# Use an integer for ease of calculation
hours_worked = int(hours_worked)
hours_paid_for = 0
# Beginning total pay is just the decimal "ending"
total_pay = end_pay
while hours_paid_for < hours_worked:
# Find the rate for the current bucket of hours
rate_filter = (rate for (lower, upper), rate in scale.items() if lower <= hours_paid_for and hours_paid_for < upper)
current_level = next(rate_filter)
print('Hour: {}'.format(hours_paid_for))
print('Pay rate: ${}'.format(current_level))
total_pay += current_level
hours_paid_for += 1
print('Total earned: ${}'.format(total_pay))
输出如下:
Hour: 0
Pay rate: $80
Hour: 1
Pay rate: $80
Hour: 2
Pay rate: $80
Hour: 3
Pay rate: $70
Hour: 4
Pay rate: $70
Hour: 5
Pay rate: $70
Hour: 6
Pay rate: $50
Hour: 7
Pay rate: $50
Hour: 8
Pay rate: $50
Hour: 9
Pay rate: $50
Hour: 10
Pay rate: $50
Hour: 11
Pay rate: $50
Hour: 12
Pay rate: $50
Hour: 13
Pay rate: $50
Hour: 14
Pay rate: $50
Total earned: $910.0
这里还有一个简洁的函数:
def calculate_pay(scale, hours_worked):
# Handle the decimal (if any) to begin with... First find the "max" rate
decimal_rate = next(rate for (lower, upper), rate in scale.items()
if lower <= hours_worked and upper >= hours_worked)
# Then calculate the last "sliver" of pay
decimal_end = hours_worked - int(hours_worked)
end_pay = decimal_end * decimal_rate
# Use an integer for ease of calculation
hours_worked = int(hours_worked)
# Hours already paid for (int)
hours_paid_for = 0
# Beginning 'total pay' can be the decimal end, if any
total_pay = end_pay
while hours_paid_for < hours_worked:
# Find the rate for the current bucket of hours
rate_filter = (rate for (lower, upper), rate in scale.items()
if lower <= hours_paid_for and hours_paid_for < upper)
current_level = next(rate_filter)
total_pay += current_level
hours_paid_for += 1
return total_pay
关于python - 将号码拆分为可变费率计费的频段,即 "tiered pricing",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46427634/
我想创建一个 sql 查询,为 2 个不同的查询一起返回结果。例如,我想要以下形式的结果:产品名称, avg(price), min(price), max(price), avg(order), m
我找不到 itemprop s 表示 schema.org 上有两种价格的产品。 价格类型有: 旧价 全新 Markdown 我无法想象,没有适合的 schema.org 标记,但经过长时间的搜索,我
我正在尝试更改 Magento 中的“特价”和“正常价格”措辞。我已经尝试编辑 Mage_Catalogue.csv、重新上传并清除缓存,但无济于事。我还在整个站点内对“常规”和“特殊”文本进行了巨大
考虑下表: sp100_id _date open close bullishness ----------------------------------------------
我试图显示某些产品变体的价格比较,但我不知道如何仅在大于零的变体的价格比较时显示它。它显示的是 0.00 美元价格的比较。 它使用 JavaScript 来动态更新价格。这是代码: 当我有一个原
我需要一些帮助来在 xml 中构建这一行。对于谷歌内容 API 我想要得到的结果是 25 目前我的代码输出这一行 25这是不正确的。 这是我的代码 b = Nokogiri::XML::Builder
我想在产品详细信息页面的价格框中显示带有名称的自定义选项价格。 我也试过这个链接但没有成功this is link i use 所以请给我建议任何解决方案。 最佳答案 首先你必须按下按钮 calcul
我想除以 {{ item.price |没有货币的货币 }} 提高 1.21。我正在隐藏输入值中调用 item.price。 When I do the below, it shows the va
因此,我想验证用户在文本字段中输入的价格: 条件(或限制): 值应始终大于零 值不能包含负号“-” 值不能多次包含小数点。还值不应以小数点开头 此外,我必须记住,这也应该适用于移动设备,因为该应用程
我使用分级价格,并对 1 到 4 之间的数量设定了固定价格,对超过 4 的数量设定了每件商品的价格。 我想修改我的购物车,为数量 >= 1 && 数量 <=4 的商品设置固定价格 我该怎么做? 这是我
Google In-app payment API 中有没有办法从应用中设置商品的价格? 我想在我的应用程序中创建一个捐赠我的应用程序按钮。会有一些预定义的捐赠金额(例如 1 美元、5 美元、10 美
我有一个数据库,其中有一列名为“价格” - 在此列中,价格四舍五入到小数点后 5 位,例如 62.083333 - 我想运行命令将“price”列中的每个值更改为仅 2 位小数,例如 62.08 是否
我的数据库中有一个名为“价格”的字段,它设置为 varchar。它包含美元符号和逗号。 我的数据库中的值是这样的: 100,000 美元 625,005 美元 115,990 美元 2,450,000
我有一个基本的 html 表单,它使用 PHP 向页面添加一些数据。我想使这个表单字段成为“价格”字段。我的 HTML 是: 如何修复此字段,以便用户无法输入随机字母、美元符号、破折号或其他奇怪的格
我试过这段代码,但没有给出解决方案。不使用引导表。我如何管理每项服务的点数。价格如何出现在适当的列中以及点数如何自动管理。 Title Rates
它们是一种将字符串格式化为 $ 价格的内置方式,例如12345.45 转换为 $12,345.45? 最佳答案 假设您使用的是 Cocoa(或只是 Foundation),您可以使用 NSNumber
我正在尝试获取 UniswapV2 上一对的价格:这是我的代码: pragma solidity ^0.5.1; import '@uniswap/v2-core/contracts/interfac
我正在寻找一种替代方法 template/catalog/product/price.phml在一个特定位置使用,并继续在所有其他位置使用现有的 price.phtml 文件。 为了进一步解释,我需要
我正在使用 VBScript(经典 ASP)和 SQL Server;我正在尝试在网站上设置一个部分,您可以在其中查看特定价格水平的产品数量。像这样的东西: $50 - $100 (4) $100 -
鉴于以下价格列表,我试图弄清楚如何仅规范化/提取数字。 INPUT DESIRED_OUTPUT CA$1399.00 1399.00 $1399.11 1399
我是一名优秀的程序员,十分优秀!