天天看點

c++ float 保留兩位小數_odoo小數精确度python round() 函數odoo小數位數設定稅金與精确度

python round() 函數

Python用于四舍五入的内建函數round() ,它的定義為

c++ float 保留兩位小數_odoo小數精确度python round() 函數odoo小數位數設定稅金與精确度

意思是, 将 小數部分保留到 ndigits 指定的 小數位,也就是 精度保持到 ndigits -1 位; 如果沒有 指定 ndigits ,則 精度 保持到 整數位。

例如

c++ float 保留兩位小數_odoo小數精确度python round() 函數odoo小數位數設定稅金與精确度

n = 5.11965811966 直接 round 時, 精确度 為整數, 即 5.0 ; round(n, 5)時,小數位保留 5位,即 5.11966

odoo小數位數設定

在 odoo中,各業務子產品設定了各自的精确度, 通過 模型 decimal.precision 定義 用于不同用途的 精确度【小數位數】, dp 模型 根據 name 傳回 小數位數, 預設為 2位

常用的精确度用途如下

c++ float 保留兩位小數_odoo小數精确度python round() 函數odoo小數位數設定稅金與精确度

在定義模型的字段時, 通過 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位 小數位

c++ float 保留兩位小數_odoo小數精确度python round() 函數odoo小數位數設定稅金與精确度

稅金與精确度

稅金可以設定為 含稅價,或者 未含稅價

c++ float 保留兩位小數_odoo小數精确度python round() 函數odoo小數位數設定稅金與精确度

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,

c++ float 保留兩位小數_odoo小數精确度python round() 函數odoo小數位數設定稅金與精确度

啟用 此選項時, 小數位數 增加 5位, 同樣對于 5.99 /1.17 的處理,則更精确, 結果為 5.1196581

轉載注明原作者 /by Jeffery