Odoo中文社区可以通过以下三个域名访问:shine-it.net , odoocn.org,odoo.net.cn

原论坛用户的基本信息和发帖这里都予以保留,请注意:原论坛用户无需重新注册新用户,但是您的密码需要重置

开发人员可以登录gitter讨论组: http://gitter.im/odoo-china/Talk, 需要github账号

如果您登录系统碰到问题,请在微信公众号留言:

Openerp onchange 金额自动转为大写



  • 1.对象里定义

    [code]
    contract_amount': fields.float('合同金额', digits_compute=dp.get_precision('contract_amount'),required=True),'contract_amount_big': fields.char('合同金额大写', required=True),


    [/code]




    2. xml里  onchange 



    <field name="contract_amount" on_change="onchange_contractamount(contract_amount)"/>




    3. 方法实现


    [code]
    def onchange_contractamount(self, cr, uid, ids, contract_amount):        if contract_amount > 0 :            big = self.numtoCny(contract_amount)            return {'value':{'contract_amount_big': big}}        else :            return {}
    [/code]


    4.需要注意的是 因为onchange里再次调用了其他方法,导致总是报参数个数不统一的异常,莫名其妙


    经过 [font=verdana]@重庆-mrshelly @南京-海飞 @上海-gavin @南京-ccdos [/font]

    [font=verdana]尤其是 总监大人解释后才明白[/font]


    重庆-mrshelly(49812643)  15:30:23
    因为你使用了 self.numtoCny 所以,  有一个默认的 self 参数传过去了.


    所以  只需要将  中文金额大写 的函数传参时注意一下就好了

    [code]
        #人民币金额转大写程序Python版本
        #Copyright: zinges at foxmail.com
        #blog: http://zingers.iteye.com
        #感谢zinges提供了Python的版本


        def numtoCny(self,contract_amount):


            capUnit = ['万','亿','万','圆','']
            capDigit = { 2:['角','分',''], 4:['仟','佰','拾','']}
            capNum=['零','壹','贰','叁','肆','伍','陆','柒','捌','玖']
            snum = str('%019.02f') % contract_amount
            if snum.index('.')>16:
                return ''
            ret,nodeNum,subret,subChr='','','',''
            CurChr=['','']
            for i in range(5):
                j=int(i*4+math.floor(i/4))
                subret=''
                nodeNum=snum[j:j+4]
                lens=len(nodeNum)
                for k in range(lens):
                    if int(nodeNum[k:])==0:
                        continue
                    CurChr[k%2] = capNum[int(nodeNum[k:k+1])]
                    if nodeNum[k:k+1] != '0':
                        CurChr[k%2] += capDigit[lens][k]
                    if  not ((CurChr[0]==CurChr[1]) and (CurChr[0]==capNum[0])):
                        if not((CurChr[k%2] == capNum[0]) and (subret=='') and (ret=='')):
                            subret += CurChr[k%2]
                subChr = [subret,subret+capUnit][subret!='']
                if not ((subChr == capNum[0]) and (ret=='')):
                    ret += subChr


            return [ret,capNum[0]+capUnit[3]][ret=='']
    [/code]



  • 1.对象里定义

    [code]
    contract_amount': fields.float('合同金额', digits_compute=dp.get_precision('contract_amount'),required=True),'contract_amount_big': fields.char('合同金额大写', required=True),


    [/code]




    2. xml里  onchange 



    <field name="contract_amount" on_change="onchange_contractamount(contract_amount)"/>




    3. 方法实现


    [code]
    def onchange_contractamount(self, cr, uid, ids, contract_amount):        if contract_amount > 0 :            big = self.numtoCny(contract_amount)            return {'value':{'contract_amount_big': big}}        else :            return {}
    [/code]


    4.需要注意的是 因为onchange里再次调用了其他方法,导致总是报参数个数不统一的异常,莫名其妙


    经过 [font=verdana]@重庆-mrshelly @南京-海飞 @上海-gavin @南京-ccdos [/font]

    [font=verdana]尤其是 总监大人解释后才明白[/font]


    重庆-mrshelly(49812643)  15:30:23
    因为你使用了 self.numtoCny 所以,  有一个默认的 self 参数传过去了.


    所以  只需要将  中文金额大写 的函数传参时注意一下就好了

    [code]
        #人民币金额转大写程序Python版本
        #Copyright: zinges at foxmail.com
        #blog: http://zingers.iteye.com
        #感谢zinges提供了Python的版本


        def numtoCny(self,contract_amount):


            capUnit = ['万','亿','万','圆','']
            capDigit = { 2:['角','分',''], 4:['仟','佰','拾','']}
            capNum=['零','壹','贰','叁','肆','伍','陆','柒','捌','玖']
            snum = str('%019.02f') % contract_amount
            if snum.index('.')>16:
                return ''
            ret,nodeNum,subret,subChr='','','',''
            CurChr=['','']
            for i in range(5):
                j=int(i*4+math.floor(i/4))
                subret=''
                nodeNum=snum[j:j+4]
                lens=len(nodeNum)
                for k in range(lens):
                    if int(nodeNum[k:])==0:
                        continue
                    CurChr[k%2] = capNum[int(nodeNum[k:k+1])]
                    if nodeNum[k:k+1] != '0':
                        CurChr[k%2] += capDigit[lens][k]
                    if  not ((CurChr[0]==CurChr[1]) and (CurChr[0]==capNum[0])):
                        if not((CurChr[k%2] == capNum[0]) and (subret=='') and (ret=='')):
                            subret += CurChr[k%2]
                subChr = [subret,subret+capUnit][subret!='']
                if not ((subChr == capNum[0]) and (ret=='')):
                    ret += subChr


            return [ret,capNum[0]+capUnit[3]][ret=='']
    [/code]



  • 不明觉厉.....................

    分享便是极好的....



  • 这个 金额转大写  完美不 ?



  • 我简单测试了下,一直测到9位数,表现良好



  • 测试程序代码正常,在数据维护时出现错误:
        subChr = [subret,subret+capUnit][subret!='']
    TypeError: cannot concatenate 'str' and 'list' objects

    有待解决!



  • [quote author=openerp_feng link=topic=14575.msg27073#msg27073 date=1387183648]
    测试程序代码正常,在数据维护时出现错误:
        subChr = [subret,subret+capUnit][subret!='']
    TypeError: cannot concatenate 'str' and 'list' objects

    有待解决!
    [/quote]


    测试数据呢,请提供一下



  • 123
    123.785
    随便录几个数字都是同样的错误



  • 因为出现这样的错误提示:
        subChr = [subret,subret+capUnit][subret!='']
    TypeError: cannot concatenate 'str' and 'list' objects

    所以,需要这样修改:
    subChr = [subret,subret+[color=red]"".join([/color]capUnit[color=red])[/color]][subret!='']



  • 有价值的东东,我也极想要



  • 可以参考下如文件,进行转换大写金额。。



  • 很有价值,谢谢分享,有待测试。


登录后回复
 

与 Odoo 中文社区 的连接断开,我们正在尝试重连,请耐心等待