Skip to Content
Odoo Meniu
  • Autentificare
  • Try it free
  • Aplicații
    Finanțe
    • Contabilitate
    • Facturare
    • Cheltuieli
    • Spreadsheet (BI)
    • Documente
    • Semn
    Vânzări
    • CRM
    • Vânzări
    • POS Shop
    • POS Restaurant
    • Abonamente
    • Închiriere
    Site-uri web
    • Constructor de site-uri
    • eCommerce
    • Blog
    • Forum
    • Live Chat
    • eLearning
    Lanț Aprovizionare
    • Inventar
    • Producție
    • PLM
    • Achiziție
    • Maintenance
    • Calitate
    Resurse Umane
    • Angajați
    • Recrutare
    • Time Off
    • Evaluări
    • Referințe
    • Flotă
    Marketing
    • Social Marketing
    • Marketing prin email
    • SMS Marketing
    • Evenimente
    • Automatizare marketing
    • Sondaje
    Servicii
    • Proiect
    • Foi de pontaj
    • Servicii de teren
    • Centru de asistență
    • Planificare
    • Programări
    Productivitate
    • Discuss
    • Aprobări
    • IoT
    • VoIP
    • Knowledge
    • WhatsApp
    Aplicații Terțe Odoo Studio Platforma Odoo Cloud
  • Industrii
    Retail
    • Book Store
    • Magazin de îmbrăcăminte
    • Magazin de Mobilă
    • Magazin alimentar
    • Magazin de materiale de construcții
    • Magazin de jucării
    Food & Hospitality
    • Bar and Pub
    • Restaurant
    • Fast Food
    • Guest House
    • Distribuitor de băuturi
    • Hotel
    Proprietate imobiliara
    • Real Estate Agency
    • Firmă de Arhitectură
    • Construcție
    • Estate Managament
    • Grădinărit
    • Asociația Proprietarilor de Proprietăți
    Consultanta
    • Firma de Contabilitate
    • Partener Odoo
    • Agenție de marketing
    • Law firm
    • Atragere de talente
    • Audit & Certification
    Producție
    • Textil
    • Metal
    • Mobilier
    • Mâncare
    • Brewery
    • Cadouri corporate
    Health & Fitness
    • Club Sportiv
    • Magazin de ochelari
    • Centru de Fitness
    • Wellness Practitioners
    • Farmacie
    • Salon de coafură
    Trades
    • Handyman
    • IT Hardware and Support
    • Asigurare socială de stat
    • Cizmar
    • Servicii de curățenie
    • HVAC Services
    Altele
    • Organizație nonprofit
    • Agenție de Mediu
    • Închiriere panouri publicitare
    • Fotografie
    • Închiriere biciclete
    • Asigurare socială
    Browse all Industries
  • Comunitate
    Învăță
    • Tutorials
    • Documentație
    • Certificări
    • Instruire
    • Blog
    • Podcast
    Empower Education
    • Program Educațional
    • Scale Up! Business Game
    • Visit Odoo
    Obține Software-ul
    • Descărcare
    • Compară Edițiile
    • Lansări
    Colaborați
    • Github
    • Forum
    • Evenimente
    • Translations
    • Devino Partener
    • Services for Partners
    • Înregistrează-ți Firma de Contabilitate
    Obține Servicii
    • Găsește un Partener
    • Găsiți un contabil
    • Meet an advisor
    • Servicii de Implementare
    • Referințe ale clienților
    • Suport
    • Actualizări
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Obține un demo
  • Prețuri
  • Ajutor

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

  • CRM
  • e-Commerce
  • Contabilitate
  • Inventar
  • PoS
  • Proiect
  • MRP
All apps
Trebuie să fiți înregistrat pentru a interacționa cu comunitatea.
All Posts Oameni Insigne
Etichete (View all)
odoo accounting v14 pos v15
Despre acest forum
Trebuie să fiți înregistrat pentru a interacționa cu comunitatea.
All Posts Oameni Insigne
Etichete (View all)
odoo accounting v14 pos v15
Despre acest forum
Suport

Press a button and download a file, how?

Abonare

Primiți o notificare când există activitate la acestă postare

Această întrebare a fost marcată
pythonfiledownloadodooV8
6 Răspunsuri
68905 Vizualizări
Imagine profil
E.M.

I would like to make Odoo download a file (from a text string for example) when a button is clicked. Is there any example I could start with or can anyone provide a basic code structure for downloading a file?

Thanks

3
Imagine profil
Abandonează
OdooBot
thanks that is great

On Sun, Mar 17, 2019 at 6:39 PM Oleksandr Komarov <komarovalea@gmail.com> wrote:

The easiest way to do this is using Transient model:

1. Create Transient Model with Binary field:

class GetFile(models.TransientModel):

_name = 'save.file.wizard'file_name = fields.Char('File name', readonly=True)

my_file = fields.Binary('File data', readonly=True,

help='File(jpg, csv, xls, exe, any binary or text format)')

2. Create Button on the Form in any Model(for example 'some_model'):

<button name="save_to_file" string="Save to file" type="object"

class="oe_stat_button oe_read_only" icon="fa-download"/>

3. Create function 'save_to_file' in model 'some_model':

@api.multi

def save_to_file(self):

some_data = 'This is data of file as String type'

my_file = self.env['save.file.wizard'].create({

'file_name': 'my-file.txt',

'xml_file': base64.b64encode(str.encode(xml_text)),

})

return {

'name': _('Download File'),

'res_id': my_file.id,

'res_model': 'o1c.save.conf',

'target': 'new',

'type': 'ir.actions.act_window',

'view_id': self.env.ref('my_module_name.save_file_wizand_view_done').id,

'view_mode': 'form',

'view_type': 'form',

}

4. Create Form for downloading files:

<record id="save_file_wizand_view_done" model="ir.ui.view">

<field name="name">save.file.wizard.form</field>

<field name="model">save.file.wizard</field>

<field name="arch" type="xml">

<form string="File download">

<group cols="2">

<div>

<field name="file_name" invisible="1" />

<label string="The file has been successfully generated." />

<field name="my_file" filename="file_name" nolabel="1" />

</div>

</group>

<footer>

<button special="cancel" string="Close" type="object" />

</footer>

</form>

</field>

</record>

That is all.

Sent by Odoo S.A. using Odoo.

Sehrish

Try this: http://learnopenerp.blogspot.com/2020/06/write-binary-data-nto-zip-file-and-downlaod-it-on-button-click-in-odoo.html

Imagine profil
Emipro Technologies Pvt. Ltd.
Cel mai bun răspuns

Hi,

We at Emipro, got this question numerous times from different Odoo developers. So here I am giving the step by step guidance how to do this.

Here all my code is in V8.

  • Create a method inside your regular model and return URL. 

For example, 

 @api.multi 
def get_stock_file(self):
    return {
            'type' : 'ir.actions.act_url',
            'url': '/web/binary/download_document?model=wizard.product.stock.report&field=datas&id=%s&filename=product_stock.xls'%(self.id),
            'target': 'self',
}

Here I have returned URL with model and some info. Now in next step i will catch that URL to a controller method.

( just like file you can see in /web/controllers/main.py )

  • Make a controller class and catch that url and do process for download excel file.

from openerp import http
from openerp.http import request
from openerp.addons.web.controllers.main import serialize_exception,content_disposition
import base64
class Binary(http.Controller):
@http.route('/web/binary/download_document', type='http', auth="public")
@serialize_exception
def download_document(self,model,field,id,filename=None, **kw):
    """ Download link for files stored as binary fields.
    :param str model: name of the model to fetch the binary from
     :param str field: binary field
     :param str id: id of the record from which to fetch the binary
    :param str filename: field holding the file's name, if any
    :returns: :class:`werkzeug.wrappers.Response`
    """
    Model = request.registry[model]
    cr, uid, context = request.cr, request.uid, request.context
    fields = [field]
    res = Model.read(cr, uid, [int(id)], fields, context)[0]
    filecontent = base64.b64decode(res.get(field) or '')
    if not filecontent:
         return request.not_found()
    else:
        if not filename:
            filename = '%s_%s' % (model.replace('.', '_'), id)
            return request.make_response(filecontent,
                            [('Content-Type', 'application/octet-stream'),
                             ('Content-Disposition', content_disposition(filename))])

In above method I have got the ID from url and then applied some calculation and return the http response from request. Whatever values I have passed from wizard to controller method, I will get them on controller method.

( See below, I have passed model, field, id and filename from url )

/web/binary/download_document?model=wizard.product.stock.report&amp;field=datas&amp;id=%s&amp;filename=product_stock.xls
def download_document(self,model,field,id,filename=None, **kw):

I have returned Excel file but you can return any kind of file and even an attachment from database binary field too.

By apply code like above, you will able to return any file on button click without intervention of binary field.

I hope this answer will add extra spice into your knowledge and make your Odoo technical understanding more delicious.

Odoo Technical notes is published for this. You can view How to download any file on button click ?  and review it.

10
Imagine profil
Abandonează
E.M.
Autor

This is super detailed and extremely useful. I have pending to try in my project as we need it to generate custom printing files for a thermal printer. Thanks a lot.

Sarina

Does this code work for odoo10 as well . I got error while using these codes.

res = Model.read(model,cr, uid, [int(id)], fields, context)[0]

TypeError: unbound method read() must be called with kyc.clients instance as first argument (got unicode instance instead)

Imagine profil
Oleksandr Komarov
Cel mai bun răspuns

The easiest way to do this is using Transient model:

1. Create Transient Model with Binary field:

class GetFile(models.TransientModel):

_name = 'save.file.wizard'file_name = fields.Char('File name', readonly=True)

my_file = fields.Binary('File data', readonly=True,

help='File(jpg, csv, xls, exe, any binary or text format)')

2. Create Button on the Form in any Model(for example 'some_model'):

<button name="save_to_file" string="Save to file" type="object"

class="oe_stat_button oe_read_only" icon="fa-download"/>

3. Create function 'save_to_file' in model 'some_model':

@api.multi

def save_to_file(self):

some_data = 'This is data of file as String type'

my_file = self.env['save.file.wizard'].create({

'file_name': 'my-file.txt',

'xml_file': base64.b64encode(str.encode(xml_text)),

})

return {

'name': _('Download File'),

'res_id': my_file.id,

'res_model': 'o1c.save.conf',

'target': 'new',

'type': 'ir.actions.act_window',

'view_id': self.env.ref('my_module_name.save_file_wizand_view_done').id,

'view_mode': 'form',

'view_type': 'form',

}

4. Create Form for downloading files:

<record id="save_file_wizand_view_done" model="ir.ui.view">

<field name="name">save.file.wizard.form</field>

<field name="model">save.file.wizard</field>

<field name="arch" type="xml">

<form string="File download">

<group cols="2">

<div>

<field name="file_name" invisible="1" />

<label string="The file has been successfully generated." />

<field name="my_file" filename="file_name" nolabel="1" />

</div>

</group>

<footer>

<button special="cancel" string="Close" type="object" />

</footer>

</form>

</field>

</record>

That is all.

2
Imagine profil
Abandonează
Imagine profil
Akhil P Sivan
Cel mai bun răspuns

Hi,

You may try using a Binary field.

file = fields.Binary(string='File')
2
Imagine profil
Abandonează
Sehrish

Thanks it works in my case. I use binary field in some of my tasks, have a look: http://learnopenerp.blogspot.com/2016/06/using-binary-fields-in-odoo.html

Imagine profil
Bryan Sandoval
Cel mai bun răspuns

def get_input_template(self):

    url = str('/hr_horizontal_payroll/static/src/xls/template.xlsx')

    return {'type' : 'ir.actions.act_url','url': url,'target': 'self','tag': 'reload', }

0
Imagine profil
Abandonează
Imagine profil
E.M.
Autor Cel mai bun răspuns

This works fine but I do not fully understand this part of the code:

Model = request.registry[model]     
cr, uid, context = request.cr, request.uid, request.context     
fields = [field]
res = Model.read(cr, uid, [int(id)], fields, context)[0]

What does Model contain?

What does fields contain?

What does res contain?

0
Imagine profil
Abandonează
David Yao

hey, I got the same problem, did you figure out how?

Imagine profil
chesucr
Cel mai bun răspuns
This works in Odoo 11 at least. If you have a binary field in any model:

@api.multi
def crete_and_download_dummy_field(self):

# store here your binary file into the dummy field

return {
'name': 'FEC',
'type': 'ir.actions.act_url',
'url': '/web/content/?model=sale.order&id={}&field=dummy&filename_field=dummy_filename&download=true'.format(
self.id
),
'target': 'self',
}

If you just want a link to download it in a form you can create a binary file and its name

mock_pdf = fields.Binary(string='Mock pdf')

mock_pdf_filename = fields.Char(
string='Mock PDF Filename',
compute='_compute_mock_pdf_filename'
)

@api.depends('mock_pdf')
def _compute_mock_pdf_filename(self):
self.ensure_one()
name = self.name.replace('/', '_')
name = name.replace('.', '_')
name = name + '.pdf'
self.mock_pdf_filename = name

And in the form

<field name="mock_pdf_filename" invisible="1" />
<field name="mock_pdf" filename="mock_pdf_filename" />
0
Imagine profil
Abandonează
osama khalid

perfect ,worked for me in odoo13 as well,

Enjoying the discussion? Don't just read, join in!

Create an account today to enjoy exclusive features and engage with our awesome community!

Înscrie-te
Related Posts Răspunsuri Vizualizări Activitate
[8.0]How to confirm an element's state from: action_confirm (MRP_REPAIR)
python odooV8
Imagine profil
1
mai 21
4987
How to get the file downloaded at the server?
python button file download controllers
Imagine profil
4
iun. 20
7314
How to save data in readonly field in openerp?
python odooV8
Imagine profil
Imagine profil
Imagine profil
Imagine profil
4
oct. 19
10902
How to multiply sequence by non-int Rezolvat
python odooV8
Imagine profil
Imagine profil
1
ian. 18
10334
Data in the txt file are all in one line
python line file download txt
Imagine profil
0
sept. 17
4368
Comunitate
  • Tutorials
  • Documentație
  • Forum
Open Source
  • Descărcare
  • Github
  • Runbot
  • Translations
Servicii
  • Hosting Odoo.sh
  • Suport
  • Actualizare
  • Custom Developments
  • Educație
  • Găsiți un contabil
  • Găsește un Partener
  • Devino Partener
Despre Noi
  • Compania noastră
  • Active de marcă
  • Contactați-ne
  • Locuri de muncă
  • Evenimente
  • Podcast
  • Blog
  • Clienți
  • Aspecte juridice • Confidențialitate
  • Securitate
الْعَرَبيّة 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 este o suită de aplicații de afaceri open source care acoperă toate nevoile companiei dvs.: CRM, comerț electronic, contabilitate, inventar, punct de vânzare, management de proiect etc.

Propunerea de valoare unică a Odoo este să fie în același timp foarte ușor de utilizat și complet integrat.

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