* 打开XML-RPC 连接
    >>> import xmlrpclib
    >>> srv, db = 'http://localhost:8069', 'v8dev'
    >>> user, pwd = 'admin', 'admin'
    >>> common = xmlrpclib.ServerProxy('%s/xmlrpc/2/common' % srv)
    >>> common.version()
    {'server_version_info': [8, 0, 0, 'final', 0], 'server_serie':
    '8.0', 'server_version': '8.0', 'protocol_version': 1}
   
    依赖 xmlrpclib 
   
    #验证
        >>> uid = common.authenticate(db, user, pwd, {})
        >>> print uid
   
    #取数据
        >>> api = xmlrpclib.ServerProxy('%s/xmlrpc/2/object' % srv)
       
       
        >>> api.execute_kw(db, uid, pwd, 'res.partner', 'search_count', [[]])
            得到记录集的总数
       
        >>> api.execute_kw(db, uid, pwd, 'res.partner', 'search',
            [[('country_id', '=', 'be'), ('parent_id', '!=', False)]])
           
            [43, 42]
            得到记录集的id序列
           
        >>> api.execute_kw(db, uid, pwd, 'res.partner', 'read', [[43]],
            {'fields': ['id', 'name', 'parent_id']})
           
            [{'parent_id': [7, 'Agrolait'], 'id': 43, 'name': 'Michel
            Fletcher'}]   
            得到记录
           
        >>> api.execute_kw(db, uid, pwd, 'res.partner', 'search_read',
            [[('country_id', '=', 'be'), ('parent_id', '!=', False)]],
            {'fields': ['id', 'name', 'parent_id']})
       
    #其它方法
    >>> api.execute_kw(db, uid, pwd, 'res.partner', 'create', [{'name':
        'Packt'}])
        75
    >>> api.execute_kw(db, uid, pwd, 'res.partner', 'write', [[75],
        {'name': 'Packt Pub'}])
        True
    >>> api.execute_kw(db, uid, pwd, 'res.partner', 'read', [[75], ['id',
        'name']])
        [{'id': 75, 'name': 'Packt Pub'}]
    >>> api.execute_kw(db, uid, pwd, 'res.partner', 'unlink', [[75]])
        True
       
* 做一个桌面应用 用到接口
   note_api.py
   ----------------
    import xmlrpclib

class NoteAPI():

def __init__(self, srv, db, user, pwd):
            common = xmlrpclib.ServerProxy( '%s/xmlrpc/2/common' % srv)
            self.api = xmlrpclib.ServerProxy('%s/xmlrpc/2/object' % srv)
            self.uid = common.authenticate(db, user, pwd, {})
            self.pwd = pwd
            self.db = db
            self.model = 'todo.task'
       
        def execute(self, method, arg_list, kwarg_dict=None):
            return self.api.execute_kw(
            self.db, self.uid, self.pwd, self.model,
            method, arg_list, kwarg_dict or {})   
       
        def get(self, ids=None):
            domain = [('id',' in', ids)] if ids else []
            fields = ['id', 'name']
            return self.execute('search_read', [domain, fields])
       
        def set(self, text, id=None):
            if id:
              self.execute('write', [[id], {'name': text}])
            else:
              vals = {'name': text, 'user_id': self.uid}
              id = self.execute('create', [vals])
            return id
       
        if __name__ == '__main__':
            srv, db = 'http://localhost:8069', 'v8dev'
            user, pwd = 'admin', 'admin'
            api = NoteAPI(srv, db, user, pwd)
            from pprint import pprint
            pprint(api.get())
   ----------------
   note_gui.py 
   ----------------
   from Tkinter import Text, Tk
import tkMessageBox
from note_api import NoteAPI

class NoteText(Text):
    def __init__(self, api, text='', id=None):
        self.master = Tk()
        self.id = id
        self.api = api
        Text.__init__(self, self.master, bg='#f9f3a9',
        wrap='word', undo=True)
        self.bind('<Control-n>', self.create)
        self.bind('<Control-s>', self.save)
        if id:
            self.master.title('#%d' % id)
        self.delete('1.0', 'end')
        self.insert('1.0', text)
        self.master.geometry('220x235')
        self.pack(fill='both', expand=1)
       
    def create(self, event=None):
        NoteText(self.api, '')
       
    def save(self, event=None):
        text = self.get('1.0', 'end')
        self.id = self.api.set(text, self.id)
        tkMessageBox.showinfo('Info', 'Note %d Saved.' % self.id)   
       
       
    if __name__ == '__main__':
        srv, db = 'http://localhost:8069', 'v8dev'
        user, pwd = 'admin', 'admin'
        api = NoteAPI(srv, db, user, pwd)
        for note in api.get():
            x = NoteText(api, note['name'], note['id'])
        x.master.mainloop()   
   ----------------
  
* ERPpeek
   首先要安装 erppeek
   $ pip install -U erppeek
  
   #API 用法:
    >>> import erppeek
    >>> api = erppeek.Client('http://localhost:8069', 'v8dev',
        'admin', 'admin')
    >>> api.common.version()
    >>> api.count('res.partner', [])
    >>> api.search('res.partner', [('country_id', '=', 'be'),
        ('parent_id', '!=', False)])
    >>> api.read('res.partner', [43], ['id', 'name', 'parent_id'])
   
   >>> m = api.model('res.partner')
   >>> m = api.ResPartner
  
   >>> m.count([('name', 'like', 'Packt%')]) 返回是数量
   >>> m.search([('name', 'like', 'Packt%')]) 返回是id
   >>> recs = m.browse([('name', 'like', 'Packt%')]) 返回是记录对象
  
   # CLI用法
     $ erppeek --help  可以看到详细的信息
    
    
* 到这里插件开发就讲完了

(07)odoo扩展API的更多相关文章

  1. Odoo : ORM API

    记录集 model的数据是通过数据集合的形式来使用的,定义在model里的函数执行时它们的self变量也是一个数据集合 class AModel(models.Model): _name = 'a.m ...

  2. win10桌面和手机的扩展API,判断是否有实体后退键API

    喜大普奔的win10 uap开发预览版终于出了,这次更新跟8.1的变化不是很大,但是将原本win8.1和wp8.1uap的分项目的形式,改为了整合成一个项目,经过一次编译打包成一个appx包,实现了无 ...

  3. Win(Phone)10开发第(1)弹,桌面和手机的扩展API,还我后退键

    喜大普奔的win10 uap开发预览版终于出了,这次更新跟8.1的变化不是很大,但是将原本win8.1和wp8.1uap的分项目的形式,改为了整合成一个项目,经过一次编译打包成一个appx包,实现了无 ...

  4. 【转】odoo 新API装饰器中one、model、multi的区别

    http://blog.csdn.net/qq_18863573/article/details/51114893 1.one装饰器详解 odoo新API中定义方式: date=fields.Date ...

  5. Java基础篇(02):特殊的String类,和相关扩展API

    本文源码:GitHub·点这里 || GitEE·点这里 一.String类简介 1.基础简介 字符串是一个特殊的数据类型,属于引用类型.String类在Java中使用关键字final修饰,所以这个类 ...

  6. 谷歌拼音输入法扩展API开发指南

    为了帮助开发者在谷歌拼音输入法的基本输入功能基础上,开发和定义更丰富的扩展输入功能,谷歌拼音输入法提供了以Lua脚本编程语言为基础的输入法扩展API.利用输入法扩展API,开发者可以编写自定义的输入功 ...

  7. Odoo的@api.装饰器

    转载请注明原文地址:https://www.cnblogs.com/cnodoo/p/9281437.html Odoo自带的api装饰器主要有:model,multi,one,constrains, ...

  8. odoo里API解读

    Odoo自带的api装饰器主要有:model,multi,one,constrains,depends,onchange,returns 七个装饰器. multimulti则指self是多个记录的合集 ...

  9. Python使用Odoo外部api

    Odoo服务器提供一个外部API,该API由其web客户端使用,也可以被支持XML-RPC或 JSON-RPC协议的编程语言(例如:Python.PHP.Ruby和Java)使用. 使用XML-RPC ...

随机推荐

  1. 在Quartus II中分配管脚的两种常用方法

    在Quartus II中分配管脚的两种常用方法 示范程序 seg7_test.v 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 /* * ...

  2. BZOJ 2436 Noi嘉年华(优化DP)

    题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=2436 题意:有一些活动,起始时间持续时间已知.有两个场地.每个活动最多只能在一个场地举行 ...

  3. UVA 437 十九 The Tower of Babylon

    The Tower of Babylon Time Limit:3000MS     Memory Limit:0KB     64bit IO Format:%lld & %llu Subm ...

  4. <iframe>标签的一些说明

    <iframe>标签里的marginwidth/marginheight属性定义的是框架内部的margin(框架和其父元素之间的margin可以用style="margin:.. ...

  5. Dbcp2抛出org.apache.commons.dbcp2.LifetimeExceededException

    三月 24, 2016 5:16:33 下午 org.apache.commons.dbcp2.BasicDataSource onSwallowException 警告: An internal o ...

  6. PHPwebshell分析

    这几天已知在做webshell的检测,JSP的不说了,特征检测起来很好匹配到,而且全是一家亲,互相模仿的居多. 今天看了一篇文章,看到14年蘑菇的webshell的后门然后很不错. ========= ...

  7. Spring与其他Web框架集成

    Spring与多种流行Web应用框架(Struts.JSF和DWR)集成的方法. Spring强大的IoC容器和企业支持特性使其十分适于实现Java EE应用的服务和持续层. 对于表现层,可以在许多不 ...

  8. zoj 1648 判断线段是否相交

    链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=648 Circuit Board Time Limit: 2 Second ...

  9. NoSQL数据库的分布式模型

    NoSQL数据库的分布式模型 单一服务器 在一个服务器完全能够胜任工作时就没必要考虑分布式,这样部署简单,维护也方便很多: 分片 特点 数据的各个部分存放在集群的不同服务器中: 比如按字母来划分:以a ...

  10. yii 中引入js 和css 的方式

    在yii中 我们需要引入css 和 js 的时候,yii 自身有需要的类. 当我在views 视图层中引入css 和 js , <?php Yii::app()->clientScript ...