2

sum_taxesこのメソッドはどのようにlotパラメータ セットを取得していますか? これは openerp のオークション アドオンのコード サンプルです。

    import pooler
    import time
    from report import report_sxw
    from osv import osv

    class seller_form_report(report_sxw.rml_parse):
        def __init__(self, cr, uid, name, context):
            super(seller_form_report, self).__init__(cr, uid, name, context=context)
            lot=self.pool.get('auction.lots').browse(cr,uid,uid)
            #address=lot.bord_vnd_id.address_get(self.cr,self.uid,[partner.id])
        #   partner=lot.bord_vnd_id.partner_id
        #   address=partner.address and partner.address[0] or ""
        #   street = address and address.street or ""



            self.localcontext.update({
                'time': time,
                'sum_taxes': self.sum_taxes,
                'sellerinfo' : self.seller_info,
                'grand_total' : self.grand_seller_total,
        #       'street':street,
        #       'address':address,
    })


    def sum_taxes(self, lot):
        taxes=[]
        amount=0.0
        if lot.bord_vnd_id.tax_id:
            taxes.append(lot.bord_vnd_id.tax_id)
        elif lot.auction_id and lot.auction_id.seller_costs:
            taxes += lot.auction_id.seller_costs
        tax=self.pool.get('account.tax').compute(self.cr,self.uid,taxes,lot.obj_price,1)
        for t in tax:
            amount+=t['amount']
        return amount
    def seller_info(self):
        objects = [object for object in self.localcontext.get('objects')]
        ret_dict = {}
        ret_list = []
        for object in objects:

            partner = ret_dict.get(object.bord_vnd_id.partner_id.id,False)
            if not partner:
                ret_dict[object.bord_vnd_id.partner_id.id] = {'partner' : object.bord_vnd_id.partner_id or False,'lots':[object]}
            else:
                lots = partner.get('lots')
                lots.append(object)
#       buyer_ids=self.pool.get(auction.lots).read(cr,uid,lot)
        return ret_dict.values()
    def grand_seller_total(self,o):
        grand_total = 0
        for oo in o:
            grand_total =grand_total + oo['obj_price']+ self.sum_taxes(oo)
        return grand_total


report_sxw.report_sxw('report.seller_form_report', 'auction.lots', 'addons/auction/report/seller_form_report.rml', parser=seller_form_report)
# vim:expandtab:smartindent:tabstop=4:softtabstop=4:shiftwidth=4:
4

2 に答える 2

1

そのコードで実際に関数を呼び出しているわけではありません。関数はおそらくレポート内から呼び出され、そこにロットパラメーターを渡します。投稿したコード例では、関数ポインターをコンテキストに入れているだけです。

OpenERP レポートの詳細については、開発者向け書籍のレポート セクションをご覧ください。また、Eclipse で OpenERP サーバーを実行し、デバッグ モードでコードをステップ実行することも非常に役立ちます。次に、メソッドがどこsum_taxes()から呼び出されているかを確認できます。

于 2010-12-14T20:02:41.853 に答える
1

次のファイルを確認してくださいuction/report/buyer_form_report.sxw
[[ repeatIn(o['lots'],'oo') ]] [[ oo.obj_num ]]ここで 'oo' が定義され、そのように呼び出されます[[ oo.obj_price + sum_taxes(oo) ]]

このレポートはモデルに登録されているため、ユーザーがレポートをクリックすると、auction.lotsが返されます!!!BrowseRecordactive_id

于 2010-12-14T12:42:34.400 に答える