1.修改Gemfile

# PDF generator
gem 'prawn'
gem 'prawn-table' # Excel generator
gem 'rubyXL' #Zip generator
gem 'rubyzip'

bundle install

2.生成附件

export.rb

requere 'csv'
class Export
def export file_type,data
file_name = "file_name"
attachment = case file_type
when 'csv'
generate_csv(data)
when 'zip'
generate_zip(data)
when 'excel'
generate_excel(data)
end
ExportMailer.with_attachment(attachment, file_name).deliver_now
end

#生成csv
def generate_csv data
file = Tempfile.new ['export', '.csv']
file.write(csv_data(data))
file
end

#生成excel
def generate_excel data
file = Tempfile.new ['export', '.xlsx']
file.write(excel_data(data))
file
end

#生成zip
def generate_zip data
pdf_files = Hash.new
data.find_each do |item|
file = Tempfile.new
pdf = Prawn::Document.new
pdf.font('path/to/font') do
pdf.text "item_data"
end
pdf.render_file file
pdf_files[item] = file
end
write_to_zip(pdf_files)
end def csv_data data
CSV.generate(encoding: 'gbk') do |csv|
data.each do |record|
csv << record.to_a
end
end
end def excel_data data
excel = RubyXL::Workbook.new
sheet = excel.worksheets.first
sheet.sheet_name = "sheet_1"
data.each_with_index do |record,m|
record.each.with_index{|content,n|
sheet.add_cell(m,n,content)
}
end
excel.stream.read
end def write_to_zip queue
file = Tempfile.new ['export', '.zip']
Zip::File.open file.path, Zip::File::CREATE do |zip|
zip.get_output_stream(".keep") { |os| os.write "keep file" }
queue.each do |name, pdf|
pdf.rewind
zip.get_output_stream("#{name}.pdf"){ |stream| stream.write pdf.read }
end
end
file
end end

3.发送邮件

export_mailer.rb

class ExportMailer < ApplicationMailer
def with_attachment attatchment_file, filename
attatchment_file.rewind
file_name = "#{filename}#{File.extname(attatchment_file.path)}"
attachments[file_name] = File.read(attatchment_file.path)
mail(to: test@email.com, subject: '发送附件测试')
end end

Rails中生成并在ActionMailer附件中发送csv、excel、pdf、zip文件的更多相关文章

  1. delphi中的idhttpserver如何才能收到idhttp发送来的exe\rar文件呢

    http://zhidao.baidu.com/link?url=-q2oXqYCKBZ9OgFDEHAcQwQEY_NroHcqGvVfKW67X5sF9LdjAAB_HPXQo04VxStFVS7 ...

  2. Python中,添加写入数据到已经存在的Excel的xls文件,即打开excel文件,写入新数据

    背景 Python中,想要打开已经存在的excel的xls文件,然后在最后新的一行的数据. 折腾过程 1.找到了参考资料: writing to existing workbook using xlw ...

  3. Android将日志信息自动发送到指定的邮箱中 邮件的内容以附件形式发送

    今日整合了网上一些大神的例子(具体看了那些大神的?这个真不好意思我忘记了.下次再整合一定给大家补上,这次也只有默默的给那几个大神说声抱歉了.)做了一个“记录android项目中的日志信息,并将日志信息 ...

  4. idel 中 生成 jar包 和项目中自己需要的包

    一.首先在自己的项目中创建一个类类中创建一个构造方法构造方法中传入一个字符串参数(这个字符串参数是为了传入路径) 在方法体内通过file类创建文件夹(换而言之就是项目中的包) 二 .就是对这个项目中的 ...

  5. 怎样在 Azure 应用服务中生成和部署 Java API 应用

    先决条件 Java 开发人员工具包 8(或更高版本) 已在开发计算机上安装 Maven 已在开发计算机上安装 Git Azure 订阅付费版或试用版 HTTP 测试应用程序,如 Postman 使用 ...

  6. EBS OAF中如何在多行表中实现附件功能

    EBS OAF中如何在多行表中实现附件功能 (版权声明,本人原创或者翻译的文章如需转载,如转载用于个人学习,请注明出处:否则请与本人联系,违者必究) 在OAF中使用附件功能之前,要先明白Entity( ...

  7. 内卷时代下的前端技术-使用JavaScript在浏览器中生成PDF文档

    背景 在计量领域中,计量检定是一种重要形式,主要用于评定计量器具的计量性能,确定其量值是否准确一致,实现手段包括计量检验.出具检定证书和加封盖印等. 在检定证书这一环节,存在一个难点,就是无法在线预览 ...

  8. 如何在高并发分布式系统中生成全局唯一Id

    月整理出来,有兴趣的园友可以关注下我的博客. 分享原由,最近公司用到,并且在找最合适的方案,希望大家多参与讨论和提出新方案.我和我的小伙伴们也讨论了这个主题,我受益匪浅啊…… 博文示例: 1.     ...

  9. C# 在Word文档中生成条形码

    C# 在Word文档中生成条形码 简介 条形码是由多个不同的空白和黑条按照一定的顺序组成,用于表示各种信息如产品名称.制造商.类别.价格等.目前,条形码在我们的日常生活中有着很广泛的应用,不管是在图书 ...

随机推荐

  1. 如何清除SQL 的登录名

    复制路径 找到SqlStudio.bin 文件删除即可 SQL Server 2016 版本: C:\Users\%username%\AppData\Roaming\Microsoft\SQL Se ...

  2. 变换CALayer锚点实现模拟时钟的动画

    变换CALayer锚点实现模拟时钟的动画 变换锚点得需要一点理论知识,看下图就能明白:). https://developer.apple.com/library/ios/documentation/ ...

  3. Excel英语成绩单 吴昊

  4. Mac快捷锁屏设置

    Mac快捷锁屏设置: 1. 安全性与隐私 - 通用:进入睡眠或开始屏幕保护程序 --> “ 立即 ”. 2. 桌面与屏幕保护程序 - 触发角:启动屏幕保护程序 注:第二步中触发角可以设置四个角中 ...

  5. java接口实例

    1.开发系统时,主体架构使用接口,接口构成系统的骨架2.这样就可以通过更换接口的实现类来更换系统的实现 public class printerDemo{ public static void mai ...

  6. psql: FATAL: role “postgres” does not exist

    I'm a postgres novice. I installed the postgres.app for mac. I was playing around with the psql comm ...

  7. ZooKeeper教程(一)----Centos7下安装ZooKeeper(单机版)

    1.下载源码 官网下载地址: http://mirrors.hust.edu.cn/apache/zookeeper/ 选择最新的版本进行下载 这里选择3.4.10进行下载: wget http:// ...

  8. Webserver管理系列:12、开启关闭Ping命令

    有些时候站点打开速度会非常慢,我们要排查故障所在.须要用到Ping命令.可是Windows Server 2008防火墙默认是关闭Ping的 我们能够通过下面方法开启Ping 打开防火墙->高级 ...

  9. 【金融123】ISDA协议

    http://blog.sina.com.cn/s/blog_799af92f0100ur03.html http://www.nafmii.org.cn/ NAFMII 官方文档 NAFMII_Ma ...

  10. Mysql注入攻击与防御(思维导图笔记)