* 打开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. V-rep学习笔记:机器人逆运动学数值解法(Cyclic Coordinate Descent Method)

    When performing inverse kinematics (IK) on a complicated bone chain, it can become too complex for a ...

  2. javascript权威指南笔记--javascript语言核心(二)

    1.函数作用域:在函数内声明的所有变量在函数体内始终是可见的.这意味着在变量声明之前甚至已经可用. *“声明提前”:javascript函数里声明的所有变量(但不涉及赋值)都被提前至函数的顶部. fu ...

  3. Windows Internals学习笔记(一)概念与工具

    参考资料: 1. <Windows Internals> 2. Windows Drive Kit 3. Microsoft Windows SDK 4. WDK下载地址 知识点: 1. ...

  4. TCP三次握手及四次挥手详细 转

    一.TCP报文格式        TCP/IP协议的详细信息参看<TCP/IP协议详解>三卷本.下面是TCP报文格式图: 图1 TCP报文格式 上图中有几个字段需要重点介绍下:      ...

  5. mac系统如何进行剪切

    来源: http://jingyan.baidu.com/article/1612d5007f76e7e20e1eeeca.html 分步阅读 mac os x下没有像windows中现成的“剪切”命 ...

  6. c++ ,类型转换

    一.隐式转换 1)精度低转高,sigend转unsigend2)数值0,会转为为指针. 数组名会转换为首地址.3)bool转换 .0为false.其他为true.-1也是true...4)非const ...

  7. js之oop <一> 创建对象,构造器(class)

    js中除了基本类型,就是对象.可以说在js中处处皆对象. 由于js是弱语言,在编写的过程中很容易混淆 object 和 class 也就是对象和构造器. object(对象):一般对象都由var关键字 ...

  8. mysql 循环控制

    1.使用whileDROP PROCEDURE IF EXISTS `addstudent`;DELIMITER ;;CREATE PROCEDURE `addstudent`(iNum int)BE ...

  9. 9月java货车版速记

    运算符的优先级java自带的方法正则表达式数组和二维数组:数组遍历,填充数组,数组排序,复制数组,数组查询数组算法:冒泡,选择,反转,快速类和对象:封装,继承,多态,this关键字,抽象类和接口重写和 ...

  10. Android Fragment分页显示的实现

    分页显示有两种方式 一种是使用ViewPager 另一种是使用FragmentTransaction 上代码 1 FragmentTransaction实现方式 public class MainAc ...