<rt id="umcai"><optgroup id="umcai"></optgroup></rt>
<tr id="umcai"><small id="umcai"></small></tr><rt id="umcai"><small id="umcai"></small></rt>
<acronym id="umcai"><small id="umcai"></small></acronym>

odoo小數精確度

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": "\u589e\u503c\u7a0e17%\u8fdb\u9879\u7a0e",

"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

? ?

? ?

? ?

? ?

? ?

<rt id="umcai"><optgroup id="umcai"></optgroup></rt>
<tr id="umcai"><small id="umcai"></small></tr><rt id="umcai"><small id="umcai"></small></rt>
<acronym id="umcai"><small id="umcai"></small></acronym>