odoo 11 вносит изменения в средство визуализации отчетов из odoo 9

#python #odoo #odoo-9 #odoo-11

#python #odoo #odoo-9 #odoo-11

Вопрос:

Мы только что обновились с odoo 9 до odoo 11. в odoo 11 была удалена функция печати отчетов, что означает старый код, который я использовал из:

 report = xmlrpclib.ServerProxy('{}/xmlrpc/2/report'.format('https://odoo.example.com'))
result = report.render_report(self.odooconnection1.db, self.odooconnection1.uid, self.odooconnection1.password, 'account.report_invoice', [invoice_id])
  

теперь оно устарело.

Как мне программно загрузить отчеты в odoo 11

Комментарии:

1. Я предлагаю ознакомиться с разделами Документации по отчетам «Пользовательские отчеты» и «Отчеты — это веб-страницы».

2. спасибо за комментарий @travisw, но приведенный там код не имеет большого смысла, контекст, похоже, полностью отсутствует.

Ответ №1:

Так что это вообще не лучший способ, и это своего рода взлом, но я решил его с помощью:

Используя пакеты python requests и lxml, чтобы сделать запрос, вручную войдите на сайт odoo, а затем с помощью этого сеанса загрузите различные PDF-файлы, которые мне требовались.

 import requests
from lxml import html

def __download_report(self, invoice_ids, date_to_use):
        session_requests = requests.session()
        login_url = "https://odoo.example.com/web/login"
        result = session_requests.get(login_url)

        tree = html.fromstring(result.text)
        authenticity_token = list(set(tree.xpath("//input[@name='csrf_token']/@value")))[0]
        payload = {
            "login": "username",
            "password": "password",
            "csrf_token": authenticity_token
        }
        result = session_requests.post(
            login_url,
            data = payload,
            headers = dict(referer=login_url)
        )
        for invoice_id in invoice_ids:
            filename = self.__get_file_name(invoice_id)

            url = "https://odoo.example.com/report/pdf/account.report_invoice/" str(invoice_id)
            pdf = session_requests.get(
                url,
                stream=True
            )
            sys.stdout.write("r[%s]" % filename )
            sys.stdout.flush()
            self.__save_report(pdf, filename, date_to_use)

def __save_report(self, report_data, filename, date_to_use):
        with open(filename, 'wb') as f:
            f.write(report_data.content)