odoorpc.report¶
This module provide the Report
class to list available reports and
to generate/download them.
-
class
odoorpc.report.
Report
(odoo)¶ The Report class represents the report management service. It provides methods to list and download available reports from the server.
Note
This service have to be used through the
odoorpc.ODOO.report
property.>>> import odoorpc >>> odoo = odoorpc.ODOO('localhost', port=8069) >>> odoo.login('odoorpc_test', 'admin', 'password') >>> odoo.report <odoorpc.report.Report object at 0x7f82fe7a1d50>
-
download
(name, ids, datas=None, context=None)¶ Download a report from the server and return it as a remote file. For instance, to download the “Quotation / Order” report of sale orders identified by the IDs
[2, 3]
:>>> report = odoo.report.download('sale.report_saleorder', [2, 3])
Write it on the file system:
>>> with open('sale_orders.pdf', 'wb') as report_file: ... report_file.write(report.read()) ...
Python 2:
Returns: io.BytesIO Raise: odoorpc.error.RPCError
(wrong parameters)Raise: ValueError (received invalid data) Raise: urllib2.URLError (connection error) Python 3:
Returns: io.BytesIO Raise: odoorpc.error.RPCError
(wrong parameters)Raise: ValueError (received invalid data) Raise: urllib.error.URLError (connection error)
-
list
()¶ List available reports from the server by returning a dictionary with reports classified by data model:
>>> odoo.report.list()['account.invoice'] [{'name': u'Duplicates', 'report_name': u'account.account_invoice_report_duplicate_main', 'report_type': u'qweb-pdf'}, {'name': 'Invoices', 'report_type': 'qweb-pdf', 'report_name': 'account.report_invoice'}]
Python 2:
Returns: list of dictionaries Raise: urllib2.URLError (connection error) Python 3:
Returns: list of dictionaries Raise: urllib.error.URLError (connection error)
-