python round() 函數
Python用于四舍五入的内建函數round() ,它的定義為
意思是, 将 小數部分保留到 ndigits 指定的 小數位,也就是 精度保持到 ndigits -1 位; 如果沒有 指定 ndigits ,則 精度 保持到 整數位。
例如
n = 5.11965811966 直接 round 時, 精确度 為整數, 即 5.0 ; round(n, 5)時,小數位保留 5位,即 5.11966
odoo小數位數設定
在 odoo中,各業務子產品設定了各自的精确度, 通過 模型 decimal.precision 定義 用于不同用途的 精确度【小數位數】, dp 模型 根據 name 傳回 小數位數, 預設為 2位
常用的精确度用途如下
在定義模型的字段時, 通過 Fileds.float() 的屬性 digits_compute 設定 小數位數, 例如
price_unit = fields.Float(string='Unit Price', required=True, digits=dp.get_precision('Product Price'))
通過 dp 類的方法 get_precision 讀取 名為 product price 的精确度, 在此例, 讀取的值 應是 3, 是以 采購單價 為 3位 小數位
稅金與精确度
稅金可以設定為 含稅價,或者 未含稅價
odoo 在計算 訂單行的 未稅金額,含稅金額時, 會調用 account.tax 模型的 方法 compute_all() 進行 計算, 計算時 會以 名為 Account 的小數位數設定 作為 round() 方法的小數位數, 在此例 小數位 為 2 , 當 稅金為 17% 含稅價 5.99, 傳回
{
"taxes": [
{
"account_analytic_collected_id": false,
"account_analytic_paid_id": false,
"account_collected_id": 49,
"account_paid_id": 49,
"amount": 0.87,
"base_code_id": false,
"base_sign": 1.0,
"id": 2,
"name": "增值稅17%進項稅",
"price_unit": 5.119658119658119,
"ref_base_code_id": false,
"ref_base_sign": 1.0,
"ref_tax_code_id": false,
"ref_tax_sign": 1.0,
"sequence": 1,
"tax_code_id": false,
"tax_sign": 1.0,
"todo": 0
}
],
"total": 5.12,
"total_included": 5.99
}
算式 為 5.99 /1.17 = 5.11965811966
round(5.99/1.17, 2) = 5.12
在 compute_all() 方法中 預置了 個選項 round_globally,
啟用 此選項時, 小數位數 增加 5位, 同樣對于 5.99 /1.17 的處理,則更精确, 結果為 5.1196581
轉載注明原作者 /by Jeffery