OpenERP自定义报告文件名

时间:2013-01-21 08:29:27

标签: openerp-7

我想自定义报告文件名。

例如,当我下载发票时,我会将“Invoice.pdf”作为文件名。我想要的是'invoice_number.pdf',但我不知道如何使用动态文件名?

3 个答案:

答案 0 :(得分:2)

我找到了7.0和当前主干的方法:

  1. 要快速解决问题,请查看以下各项的Reports类:

    openerp-7.0\web\addons\web\controllers\main.py
    
  2. 报告名称在名为file_name的变量中设置:

    file_name = '%s.%s' % (file_name, report_struct['format'])
    
  3. 找到此行并在其前插入此部分:

    '''
      YP: Added proc. to create reports with real object names (the object must have a field named "name"):
      eg: "PO00006.pdf" instead of "Request For Quotation.pdf" for a single object report
          "PO00006-PO00002.pdf" instead of "Request For Quotation.pdf" for a multiple objects report
    '''
    
    # Try to get current object model and their ids from context
    if action.has_key('context'):
        action_context = action.get('context',{})
        if action_context.has_key('active_model') and action_context.has_key('active_id'):
            action_active_model = action_context.get('active_model','')
            action_active_ids = action_context.get('active_ids', [])
            if action_active_model and action_active_ids:
                # Use built-in ORM method to get data from DB
                m = req.session.model(action_active_model)
                r = m.read(action_active_ids, False, context)
                # Parse result to create a better filename
                for i, item in enumerate(r):
                  if item.has_key('name'):
                    if i == 0: 
                      file_name = ('%s') % (item['name'])
                    else:
                      file_name = ('%s-%s') % (file_name, item['name'])  
    

答案 1 :(得分:1)

  1. 要快速解决问题,请查看以下各项的Reports类:

    openerp-6.1\web\addons\web\controllers\main.py
    
  2. 报告名称在名为header的变量中设置。 根据我的需要,我只希望报告按对象名称命名(在99%的情况下都适合),所以我添加了一个名为report_name的新变量:

    report_name = action['report_name']
    if action.has_key('context'):
        action_context = action.get('context',{})
        if action_context.has_key('name'):
            report_name = action_context['name'] 
    
    return req.make_response(report,
         headers=[
             ('Content-Disposition', 'attachment; filename="%s.%s"' % (report_name, report_struct['format'])),
             ('Content-Type', report_mimetype),
             ('Content-Length', len(report))],
         cookies={'fileToken': int(token)})
    

答案 2 :(得分:1)

我找到了一个解决方案来设置默认文件名,例如附件文件名,使用xml报告定义中attachment属性中的表达式。

找到并修改此文件:openerp7 / openerp-web / addons / web / controllers / main.py。

搜索这句话:

        file_name = '%s.%s' % (file_name, report_struct['format'])

然后在之前添加此代码:

    '''Code added by Raul Paz to set the default file_name like the attach_name
        The attach_name mach with the attachment expresion from your report_xml
        <report
            id="report_webkit.YourModule_report_id"
            model="YourModule.model"        
            name="Your_report_name"
            file="YOUR_MODULE/report/YOUR_MAKO_FILE.mako"
            string="Your Text in the print button" 
            auto="False" 
            report_type="webkit"
            attachment="'Valid_filename_expresion"
            usage="default"
        />
        And
        to modify existing report sale_report.xml to manage the name:
        create in your module a file : sale_report.xml
        <?xml version="1.0" encoding="UTF-8"?>
        <openerp>
           <data>
              <record id="sale.report_sale_order" model="ir.actions.report.xml">
                  <field name="attachment">(object.name or 'Sale Order')</field>
          <field name="attachment_use" eval="True"/>
      </record>
          </data>
        </openerp>

    '''
    try:
        if action.get('attachment_use',False) and action['attachment']:
            model = context['active_model']
            cr = openerp.pooler.get_db(req.session._db).cursor()
            uid = context['uid']
            ids = context['active_ids']
            objects=openerp.pooler.get_pool(req.session._db).get(model).browse(cr,uid,ids,context=context)
            file_name=[eval(action['attachment'],{'object':x, 'time':time}) for x in objects][0]
    except:
        pass
    #end code added

好的luky