Overslaan naar inhoud
Odoo Menu
  • Aanmelden
  • Probeer het gratis
  • Apps
    Financiën
    • Boekhouding
    • Facturatie
    • Onkosten
    • Spreadsheet (BI)
    • Documenten
    • Ondertekenen
    Verkoop
    • CRM
    • Verkoop
    • Kassasysteem winkel
    • Kassasysteem Restaurant
    • Abonnementen
    • Verhuur
    Websites
    • Websitebouwer
    • E-commerce
    • Blog
    • Forum
    • Live Chat
    • eLearning
    Bevoorradingsketen
    • Voorraad
    • Productie
    • PLM
    • Inkoop
    • Onderhoud
    • Kwaliteit
    Personeelsbeheer
    • Werknemers
    • Werving & Selectie
    • Verlof
    • Evaluaties
    • Aanbevelingen
    • Wagenpark
    Marketing
    • Sociale media-marketing
    • E-mailmarketing
    • Sms-marketing
    • Evenementen
    • Marketingautomatisering
    • Enquêtes
    Diensten
    • Project
    • Urenstaten
    • Buitendienst
    • Helpdesk
    • Planning
    • Afspraken
    Productiviteit
    • Chat
    • Goedkeuringen
    • IoT
    • VoIP
    • Kennis
    • WhatsApp
    Apps van derden Odoo Studio Odoo Cloud Platform
  • Bedrijfstakken
    Detailhandel
    • Boekhandel
    • kledingwinkel
    • Meubelzaak
    • Supermarkt
    • Bouwmarkt
    • Speelgoedwinkel
    Food & Hospitality
    • Bar en Pub
    • Restaurant
    • Fastfood
    • Gastenverblijf
    • Drankenhandelaar
    • Hotel
    Vastgoed
    • Makelaarskantoor
    • Architectenbureau
    • Bouw
    • Vastgoedbeheer
    • Tuinieren
    • Vereniging van eigenaren
    Consulting
    • Accountantskantoor
    • Odoo Partner
    • Marketingbureau
    • Advocatenkantoor
    • Talentenwerving
    • Audit & Certificering
    Productie
    • Textiel
    • Metaal
    • Meubels
    • Eten
    • Brewery
    • Relatiegeschenken
    Gezondheid & Fitness
    • Sportclub
    • Opticien
    • Fitnesscentrum
    • Wellness-medewerkers
    • Apotheek
    • Kapper
    Trades
    • Klusjesman
    • IT-hardware & support
    • Zonne-energiesystemen
    • Schoenmaker
    • Schoonmaakdiensten
    • HVAC-diensten
    Andere
    • Non-profitorganisatie
    • Milieuagentschap
    • Verhuur van Billboards
    • Fotograaf
    • Fietsleasing
    • Softwareverkoper
    Browse all Industries
  • Community
    Leren
    • Tutorials
    • Documentatie
    • Certificeringen
    • Training
    • Blog
    • Podcast
    Versterk het onderwijs
    • Onderwijs- programma
    • Scale Up! Business Game
    • Bezoek Odoo
    Download de Software
    • Downloaden
    • Vergelijk edities
    • Releases
    Werk samen
    • Github
    • Forum
    • Evenementen
    • Vertalingen
    • Word een Partner
    • Services for Partners
    • Registreer je accountantskantoor
    Diensten
    • Vind een partner
    • Vind een boekhouder
    • Een adviseur ontmoeten
    • Implementatiediensten
    • Klantreferenties
    • Ondersteuning
    • Upgrades
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Vraag een demo aan
  • Prijzen
  • Help

Odoo is the world's easiest all-in-one management software.
It includes hundreds of business apps:

  • CRM
  • e-Commerce
  • Boekhouding
  • Voorraad
  • PoS
  • Project
  • MRP
All apps
Je moet geregistreerd zijn om te kunnen communiceren met de community.
Alle posts Personen Badges
Labels (Bekijk alle)
odoo accounting v14 pos v15
Over dit forum
Je moet geregistreerd zijn om te kunnen communiceren met de community.
Alle posts Personen Badges
Labels (Bekijk alle)
odoo accounting v14 pos v15
Over dit forum
Help

How to get the data inorder to generate an excel report?

Inschrijven

Ontvang een bericht wanneer er activiteit is op deze post

Deze vraag is gerapporteerd
pythonreportexceltableodoo10
2 Antwoorden
7543 Weergaven
Avatar
Kinah Guinto

Hello,
I am new in odoo. I wanted to generate a report - an excel format. I am looking for a python approach example for these sample data.

This my xml for the qweb in my pdf format:

<tbody class="table_data">
<t t-set="pickings" t-value="o.get_pickings(date_start, date_end)" />
<t t-foreach="pickings" t-as="pick">
<t t-set="line_items" t-value="o.get_line_items(pick)"/>
    <t t-foreach="line_items" t-as="line">
        <tr>
         <td><span t-esc="i"/><t t-set="i" t-value="i+1"/></td>
            <td><span t-esc="line.get('partner_name')" /></td>
            <td><span t-esc="line.get('si_number')" /></td>
            <td><span t-esc="line.get('product_name')" /></td>
            <td><span t-esc="line.get('done_qty')" /></td>
            <t t-set="qty" t-value="qty + line.get('done_qty')"/>
        </tr>
    </t>
</t>
<tr class="total">
<td colspan="3"></td>
<td><span>Total:</span></td>
<td><span t-esc="qty" /></td>
</tr>
</tbody>

I tried to display this in excel but got error.

the items:

    @api.multi
    def get_line_items(self, picking_id):
        line_items = picking_id.pack_operation_ids
        items = []
        for item in line_items:
            items.append({"product_name": item.product_id.name, "done_qty": item.qty_done, 
                          "si_number": " ".join([ invoice.name for invoice in picking_id.sale_id.invoice_ids]),
                          "partner_name": picking_id.partner_id.name })
        
       
        return items


for excel:

        sheet.write(0, 1, "REPORT", header_title)    
        sheet.write(4, 0, "CUSTOMER NAME")
        sheet.write(4, 1, "I.S. #")
        sheet.write(4, 2, "PRODUCT NAME")
        sheet.write(4, 3, "NO. OF BAGS")
               
        get_line_items = self.get_line_items(picking_id)     
                
        for i in get_line_items:
            print("get_line_items",i)      

error:

get_line_items = self.get_line_items(picking_id)
NameError: global name 'picking_id' is not defined
0
Avatar
Annuleer
Avatar
sunandan
Beste antwoord

You can try this connector from odoo appstore
It is easy to install and is integrated in excel itself
https://apps.odoo.com/apps/modules/18.0/excel_connector

3
Avatar
Annuleer
Avatar
Niyas Raphy (Walnut Software Solutions)
Beste antwoord

Hi,

If you are looking how to create excel report in odoo, see this tutorial explaining the same:  How to Create Excel report in Odoo


An example of XLSX report for partners on a module called module_name:

A python class

from odoo import models

class PartnerXlsx(models.AbstractModel):
    _name = 'report.module_name.report_name'
    _inherit = 'report.report_xlsx.abstract'

    def generate_xlsx_report(self, workbook, data, partners):
        for obj in partners:
            report_name = obj.name
            # One sheet by partner
            sheet = workbook.add_worksheet(report_name[:31])
            bold = workbook.add_format({'bold': True})
            sheet.write(0, 0, obj.name, bold)

To manipulate the workbook and sheet objects, refer to the documentation of xlsxwriter.

A report XML record

<report
    id="partner_xlsx"
    model="res.partner"
    string="Print to XLSX"
    report_type="xlsx"
    name="module_name.report_name"
    file="res_partner"
    attachment_use="False"
/>
Supporting Module:  Base report xlsx

Thanks

0
Avatar
Annuleer
Kinah Guinto
Auteur

Hello, thank you for your kind response. I updated my post. I am having an error to get the items from get_line_items().

Niyas Raphy (Walnut Software Solutions)

get_line_items = self.get_line_items(picking_id) , what is picking_id here refers to ?

Kinah Guinto
Auteur

@api.multi

def get_partner_name(self, picking_id):

partner_name = picking_id.partner_id.name

return partner_name

@api.multi

def get_line_items(self, picking_id):

line_items = picking_id.pack_operation_ids

items = []

for item in line_items:

items.append({"product_name": item.product_id.name, "done_qty": item.qty_done,

"si_number": " ".join([ invoice.name for invoice in picking_id.sale_id.invoice_ids]),

"partner_name": picking_id.partner_id.name })

return items

Geniet je van het gesprek? Blijf niet alleen lezen, doe ook mee!

Maak vandaag nog een account aan om te profiteren van exclusieve functies en deel uit te maken van onze geweldige community!

Aanmelden
Gerelateerde posts Antwoorden Weergaven Activiteit
Generate excel with a button
python report excel odoo12
Avatar
1
jul. 21
176
Excel report
python report excel odoo12
Avatar
0
apr. 21
331
Unknown report type: xlsx: - Odoo 10
report excel xlsx odoo10
Avatar
Avatar
1
nov. 18
6998
How to add image in excel report using python xlwt ? Opgelost
python image report excel xlwt
Avatar
Avatar
3
nov. 17
24182
error ConfigParser.ParsingError: File contains parsing errors
python odoo10
Avatar
0
mrt. 21
7865
Community
  • Tutorials
  • Documentatie
  • Forum
Open Source
  • Downloaden
  • Github
  • Runbot
  • Vertalingen
Diensten
  • Odoo.sh Hosting
  • Ondersteuning
  • Upgrade
  • Gepersonaliseerde ontwikkelingen
  • Onderwijs
  • Vind een boekhouder
  • Vind een partner
  • Word een Partner
Over ons
  • Ons bedrijf
  • Merkelementen
  • Neem contact met ons op
  • Vacatures
  • Evenementen
  • Podcast
  • Blog
  • Klanten
  • Juridisch • Privacy
  • Beveiliging
الْعَرَبيّة Català 简体中文 繁體中文 (台灣) Čeština Dansk Nederlands English Suomi Français Deutsch हिंदी Bahasa Indonesia Italiano 日本語 한국어 (KR) Lietuvių kalba Język polski Português (BR) română русский язык Slovenský jazyk slovenščina Español (América Latina) Español ภาษาไทย Türkçe українська Tiếng Việt

Odoo is een suite van open source zakelijke apps die aan al je bedrijfsbehoeften voldoet: CRM, E-commerce, boekhouding, inventaris, kassasysteem, projectbeheer, enz.

Odoo's unieke waardepropositie is om tegelijkertijd zeer gebruiksvriendelijk en volledig geïntegreerd te zijn.

Website made with

Odoo Experience on YouTube

1. Use the live chat to ask your questions.
2. The operator answers within a few minutes.

Live support on Youtube
Watch now