跳转至内容
  • 版块
  • 标签
  • 热门
  • 用户
  • 群组
皮肤
  • Light
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • 默认(Flatly)
  • 不使用皮肤
折叠

Odoo 中文社区

D

daishaofei

@daishaofei
关于
帖子
3
主题
3
群组
0
粉丝
0
关注
0

帖子

最新 最佳 有争议的

  • Openerp xml_rpc数据操作过快导致CannotSendRequest的解决方法
    D daishaofei

    xml_rpc操作数据库,写入过快就会报连接错误
    类似这样:

    <br />&nbsp; &nbsp; sock.execute(dbname, uid, pwd, &#039;stock.seeed.delivery&#039;, &#039;write&#039;, id, values)<br />&nbsp; File &quot;/usr/lib/python2.7/xmlrpclib.py&quot;, line 1224, in __call__<br />&nbsp; &nbsp; return self.__send(self.__name, args)<br />&nbsp; File &quot;/usr/lib/python2.7/xmlrpclib.py&quot;, line 1578, in __request<br />&nbsp; &nbsp; verbose=self.__verbose<br />&nbsp; File &quot;/usr/lib/python2.7/xmlrpclib.py&quot;, line 1264, in request<br />&nbsp; &nbsp; return self.single_request(host, handler, request_body, verbose)<br />&nbsp; File &quot;/usr/lib/python2.7/xmlrpclib.py&quot;, line 1289, in single_request<br />&nbsp; &nbsp; self.send_request(h, handler, request_body)<br />&nbsp; File &quot;/usr/lib/python2.7/xmlrpclib.py&quot;, line 1391, in send_request<br />&nbsp; &nbsp; connection.putrequest(&quot;POST&quot;, handler, skip_accept_encoding=True)<br />&nbsp; File &quot;/usr/lib/python2.7/httplib.py&quot;, line 856, in putrequest<br />&nbsp; &nbsp; raise CannotSendRequest()<br />CannotSendRequest<br />
    


    解决这个问题就是每次数据操作前登录,操作后退出,
    让我想到了装饰器,直接上代码

    <br />#encoding=utf-8<br />import xmlrpclib<br /><br />username = &#039;admin&#039; #the user<br />pwd = &#039;test&#039;&nbsp; &nbsp; &nbsp; #the password of the user<br />dbname = &#039;test&#039;&nbsp; &nbsp; #the database<br />host = &#039;http://192.168.1.116:8069&#039;<br /><br />def log_in_out(*logs,**kwlogs):<br />&nbsp; &nbsp; def deco(func):<br />&nbsp; &nbsp; &nbsp; &nbsp; def wrapper(*args,**kwargs):<br />&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; dbname,username,pwd,host = kwlogs&#91;&#039;dbname&#039;],kwlogs&#91;&#039;username&#039;],kwlogs&#91;&#039;pwd&#039;],kwlogs&#91;&#039;host&#039;]<br />&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; sock_common = xmlrpclib.ServerProxy (&#039;%s/xmlrpc/common&#039;%host)<br />&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; uid = sock_common.login(dbname, username, pwd)<br />&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; sock = xmlrpclib.ServerProxy(&#039;%s/xmlrpc/object&#039;%host)<br />&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; kwargs&#91;&#039;sock&#039;] = sock<br />&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; kwargs&#91;&#039;uid&#039;] = uid<br />&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; data = func(*args,**kwargs)<br />&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; sock_common.logout(dbname, username, pwd)<br />&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; return data<br />&nbsp; &nbsp; &nbsp; &nbsp; return wrapper<br />&nbsp; &nbsp; return deco<br /><br />##get_list<br />@log_in_out(dbname=dbname,username=username,pwd=pwd,host=host)<br />def get_list(limit=20000, date_start=None, date_end=None, sock=None, uid=None):<br />&nbsp; &nbsp; &#039;&#039;&#039;get the list of track&#039;&#039;&#039;<br />&nbsp; &nbsp; args = [(&#039;state&#039;,&#039;in&#039;, (&#039;traceable&#039;,&#039;partdone&#039;,&#039;done&#039;)), (&#039;transfer_way&#039;, &#039;not like&#039;, &#039;%自取%&#039;),<br />&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; (&#039;transfer_way&#039;, &#039;not in&#039;, (&#039;&#039;,)),&#039;|&#039;,(&#039;track_state&#039;,&#039;not like&#039;,&#039;%成功签收%&#039;),(&#039;track_state&#039;,&#039;=&#039;,False)]<br />&nbsp; &nbsp; if date_start:<br />&nbsp; &nbsp; &nbsp; &nbsp; args.insert(0, (&#039;traceable_time&#039;, &#039;&gt;=&#039;, date_start),)<br />&nbsp; &nbsp; if date_end:<br />&nbsp; &nbsp; &nbsp; &nbsp; args.insert(0, (&#039;traceable_time&#039;, &#039;&lt;=&#039;, date_end),)<br />&nbsp; &nbsp; ids = sock.execute(dbname, uid, pwd, &#039;stock.delivery&#039;, &#039;search&#039;, args)<br />&nbsp; &nbsp; ids = sorted(ids,reverse=True)[:limit]<br />&nbsp; &nbsp; print len(ids)<br />&nbsp; &nbsp; fields = &#91;&#039;id&#039;,&#039;logistic_sn&#039;,&#039;transfer_way&#039;,&#039;track_state&#039;,&#039;traceable_time&#039;,&#039;name&#039;] #fields to read<br />&nbsp; &nbsp; data = sock.execute(dbname, uid, pwd, &#039;stock.delivery&#039;, &#039;read&#039;, ids, fields) #ids is a list of id<br />&nbsp; &nbsp; return data<br /><br />@log_in_out(dbname=dbname,username=username,pwd=pwd,host=host)<br />def write_track(id,values,sock=None,uid=None):<br />&nbsp; &nbsp; sock.execute(dbname, uid, pwd, &#039;stock.delivery&#039;, &#039;write&#039;, id, values)<br />
    

  • Openerp 一次只提交一个写入
    D daishaofei

    最新写了个多线程写入数据,数据量大时得跑3个多小时,
    循环执行self.write的时候,只有在循环结束后一起写入数据,
    就是说3个小时的数据,最后一起写入,如果中间有间断,前面都是白费力,
    所以必须有一个写入,一个提交,请教buke大大,终于解决
        cr.autocommit(True)
          cr.execute(‘somesql’)
          cr.commit()
    附图可以看到每次写入的时间不同

    还是有遗留的问题,希望和大家一起讨论
    1.self.write()  怎么也执行一次写入,一次提交
    2.写入过程中怎么pass错误,程序继续执行

    引发错误
    values = {‘track_time’:'88888'}
            try:
                self.write(cr, uid, 13002, values)
            except Exception,e:
                print 'ee',e
    可以打印e但是,程序直接异常退出


  • Openerp xml通过context传当前id
    D daishaofei

    先讲使用情况
    页面设置默认值时,要根据当前对象的属性设置
    但是模型_defults 中的函数却传入不了当前id
    那可以根据万能的context传值
    贴代码
    xml中
    <field colspan= "4" name="payment_line" nolabel= "1" widget= "one2many_list" context= "{'acc_purchase_id':active_id}" >

    模型中
        _columns = {...}
        def _default_ref_account(self, cr, uid, context={}):
            acc_seeed_purchase_id = context.get('acc_purchase_id','')
        _defaults = {'ref_account':_default_ref_account,}

  • 登录

  • 没有帐号? 注册

  • 登录或注册以进行搜索。
  • 第一个帖子
    最后一个帖子
0
  • 版块
  • 标签
  • 热门
  • 用户
  • 群组