(07)odoo扩展API

* 打开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 可以看到详细的信息

* 到这里插件开发就讲完了

时间: 2024-10-23 07:21:57

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

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

喜大普奔的win10 uap开发预览版终于出了,这次更新跟8.1的变化不是很大,但是将原本win8.1和wp8.1uap的分项目的形式,改为了整合成一个项目,经过一次编译打包成一个appx包,实现了无缝跨平台. 每一个平台特有的API,就变为了扩展API,以下几种 下面,就以wp特有的后退键为例,看一下不同平台扩展api的使用. 如果你新建一个win10UAP的项目,跑在wp上运行,你会发现,后退键竟然他喵的是后台!这不是抢Home键的饭碗么! 自带的几种风格的页面,竟然是用的左上角虚拟后退键,

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

本文源码:GitHub·点这里 || GitEE·点这里 一.String类简介 1.基础简介 字符串是一个特殊的数据类型,属于引用类型.String类在Java中使用关键字final修饰,所以这个类是不可以继承扩展和修改它的方法.String类用处极广泛,在对String对象进行初始化时,和基本类型的包装器类型一样,可以不使用new关键字构造对象.(是真的妖娆...) 2.类构造和方法 String类结构 特点:final关键字修饰,实现Serializable序列化接口,Comparable

ODOO 新API修饰符

Odoo8中,API接口分为traditaional style和record style两种类型: traditional style指的就是我们在7.0中使用的类型,def(self,cr,uid,ids,context)式的语法. record style 8.0及以后版本精简化参数后的风格,只保留了self和args,形如def(self,args) Method and decorator New decorators are just mapper around the new AP

ES6知识点整理之----数组扩展----API新增

Array.from() 用于将两类对象转为真正的数组:类似数组的对象(array-like object)和可遍历(iterable)的对象(包括 ES6 新增的数据结构 Set 和 Map). 只要是部署了 Iterator 接口的数据结构,Array.from都能将其转为数组. 任何有length属性的对象,都可以通过Array.from方法转为数组,而扩展运算符就无法转换. Array.from还可以接受第二个参数,作用类似于数组的map方法,用来对每个元素进行处理,将处理后的值放入返回

DOM扩展API

选择器 document.getElementById document.getElementsByTagName document.getElementsByTagName document.getElementByClassName document.getElementsByName document.querySelector document.querySelectorAll Element Traversal childElementCount firstElementChild l

(一)chrome扩展 - API小记

browserAction 设置browser action的badge文字,badge 显示在图标上面 chrome.browserAction.setBadgeText({text:"i am test"}) 设置badge的背景颜色. // chrome.browserAction.setBadgeBackgroundColor(object details); chrome.browserAction.setBadgeBackgroundColor({ color: [255,

html5移动端根据百度地图api获取详细地址

<script type="text/javascript" src="js/BMap.js" ></script> <script type="text/javascript"> // 扩展API是否准备好,如果没有则监听"plusready"事件 if(window.plus){ plusReady(); }else{ document.addEventListener( "p

HTML5+学习笔记2-------边看代码边研究貌似还是有点问题...还在研究中api中

// 拍照 function getImage() { outSet( "开始拍照:" ); var cmr = plus.camera.getCamera(); cmr.captureImage( function ( p ) { outLine( "成功:"+p ); plus.io.resolveLocalFileSystemURL( p, function ( entry ) { createItem( entry ); }, function ( e )

Unity编辑器扩展Texture显示选择框

学习NGUI插件的时候,突然间有一个问题为什么它这些属性可以通过弹出窗口来选中呢? 而我自己写的组件只能使用手动拖放的方式=.=. Unity开发了组件Inspector视图扩展API,如果我们要写插件方便别人来使用,使用编辑器扩展API让我们的组件显示的更华丽,使用方便 Texture弹出选择框选中图片赋值: 1个组件对应1个Edit扩展器,继承Editor必须让入Editor文件夹下 MyComponent: using UnityEngine; using System.Collectio