【问题标题】:Generate a .xsl file from an encodeString从 encodeString 生成 .xsl 文件
【发布时间】:2021-08-30 05:08:52
【问题描述】:

我有一个编码字符串(excel_file),我想从这个字符串生成一个 xsl 文件。

是否可以生成一个 .xsl 文件,仅在我的 .py 文件中添加代码而不将此文件保存在本地,因为我想将此文件附加到邮件中。

att_id = self.env['ir.attachment'].create({

                    'name': 'My name',
                    'type': 'binary',
                    'datas':excel_file,
                    'datas_fname': 'Myname.xsl',
                    'res_model': 'print.invoice.cron',
                    'res_id': self.id,
                    'mimetype': 'text/csv'

                    })


                tools.email_send(email_from='sending@test.fr',
                            email_to=['recive@gmail.com'],
                            subject='Some subject',
                            body=att_id)

我正在接收附件的 id,但不是文件。并且 email_send() 没有附件属性

【问题讨论】:

  • 您可以使用电子邮件模板发送电子邮件,并可以在那里添加附件。如果您需要代码方面的帮助,请告诉我。
  • @HimanshuSharma 当然可以。但是我不需要创建模板,因为它在 cron 中,不是吗?
  • 电子邮件模板只是您要发送的电子邮件的内容模板。如果您不想等待 cron,可以使用 force send true。

标签: python email xslt odoo email-attachments


【解决方案1】:

所以这是我的建议:

att_id = self.env['ir.attachment'].create({

                    'name': 'My name',
                    'type': 'binary',
                    'datas':excel_file,
                    'datas_fname': 'Myname.xsl',
                    'res_model': 'print.invoice.cron',
                    'res_id': self.id,
                    'mimetype': 'text/csv'

                    })
template = self.env.ref(
                        'module_name.email_template', False)
ctx = dict(
                            default_model=self._name,
                            default_res_id=self.id,
                            default_use_template=bool(template),
                            default_template_id=template.id,
                            default_composition_mode='comment',
                            default_email_to=email,
                            default_lang=self.env.user.partner_id.lang,
                            default_attachment_ids=[(6, 0, att_id.ids)],
                        )
self.env['mail.template'].browse(template.id).with_context(
                            ctx).send_mail(self.id, force_send=True)

模板创建代码:

    <?xml version="1.0" encoding="utf-8"?>
    <odoo>
        <data noupdate="1">
            <record id="email_template" model="mail.template">
                <field name="name">Template Name</field>
                <field name="model_id" ref="module_name.model_your_model"/>
                <field name="email_to">${ctx.get('default_email_to')}</field>
                <field name="subject">Subject</field>
                <field name="body_html" type="html">
    <div style="margin: 0px; padding: 0px;">
        <p style="margin: 0px; padding: 0px; font-size: 13px;">
Email body
</p>
        Thanks
    </div>
                </field>
                <field name="lang">${ctx.get('default_lang')}</field>
                <field name="user_signature" eval="True"/>
                <field name="auto_delete" eval="True"/>
            </record>

        </data>
    </odoo>

请检查并告诉我它是否有效。

【讨论】:

  • 我测试了它,对于这一行 default_template_id=template.id,我得到一个错误 AttributeError: 'NoneType' object has no attribute 'id' 我认为这是因为 template = self.env.ref( 'print.invoice.cron, False) 我用 template = self.env.ref('print.invoice.cron.email_template, False) 测试但我得到了相同的结果
  • default_template_id=template.id 此行表示您必须传递模板的 id。在您的模块中创建一个自定义模板并传递 id。
  • 我得到了同样的错误。你能给我一个例子吗,我试过了:print.invoice.cron.formprint.invoice.cronform
  • 我已经用模板创建示例更新了我的答案。请检查。
  • 好的,我必须用我的 cron 模板将模板放在视图中?
猜你喜欢
  • 1970-01-01
  • 2010-11-13
  • 1970-01-01
  • 2014-07-16
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多