跳至内容
菜单
此问题已终结
6 回复
40936 查看

Hello i have created a custom module , and i dsplay the fields in a qweb report which i also created , the problem is when i look at the module i a normal list view data shows correctly like :

deposit :45.00

How ever if print the custom report : the data shown is 45.0

here is an example of my modules code :

from openerp.osv import fields,osv
from openerp import tools
class cm_rental_contracts(osv.osv):
    _name = "cm.rental.contracts"
    _description = "Camden Market Rental Contracts"
    _auto = False
    _columns = {
                 'name':fields.char('Name'),  
                 'address':fields.char('Address'),
                 'address2':fields.char('Address2'),
                 'state':fields.char('Town'),
                 'city':fields.char('City'),
                 'post_code':fields.char('Post Code'),
                 'country':fields.char('Country'),
                 'sale_items':fields.char('Items of Sale'),
                 'rent':fields.char('Rent'),
                 'outgoing':fields.char('Outgoing'),
                 'service_charge':fields.char('Service Charge'),
                 'contract_category':fields.char('Contracts Category'),
                 'deposit':fields.float('Deposit'),
                 'start_date':fields.date('Start Date'),
                 'units':fields.char('units'),
                 'invoicing_company':fields.char('Invoicing Company'),
                 'invoicing_company_number':fields.char('Invoicing Company Number')

 

here is an example of a line of in my qweb report in which calls data from my module and displays it :

 <font t-field ="o.rent" face="Arial, serif">:</font>

 

Is there any way to fix this ?

 

形象
丢弃
最佳答案

Hello 

You can take reference of below code

<span t-esc="sum(docs.mapped('amount'))" t-options='{"widget": "float", "precision": 2}'/>
Best Thanks,
Ankit H Gandhi.


形象
丢弃

Thanks That's Work

最佳答案

You can use python for format your decimal numbers. "t-esc" attribute in qweb allows you to write python code, eg:


<span t-esc="'%.2f'%(t.amount)"/></span> 

You can add some computation as well

<span t-esc="'%.2f'%(t.amount * 100)"/></span>



This will print value to exactly two decimal places


形象
丢弃
最佳答案

Try simmilar to (o.currency_id is mandatory):

<span t-field="o.deposit" t-field-options='{"widget": "monetary", "display_currency": "o.currency_id"}'/>

形象
丢弃
编写者 最佳答案

Thanks guys , for the help both examples worked .

形象
丢弃

If worked, you vote and/or accept good answer or answers.

最佳答案

Hello Erhuvwu Akpobaro

You need to import 
import openerp.addons.decimal_precision as dp

 'rent':fields.char('Rent') should be  'rent':fields.float('Rent',digits_compute= dp.get_precision('Account')),

Thank You

 

 

形象
丢弃
相关帖文 回复 查看 活动
4
1月 25
45837
0
10月 24
2149
0
10月 24
5
2
9月 24
2777
0
8月 23
2300