Rails中生成并在ActionMailer附件中发送csv、excel、pdf、zip文件
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文件的更多相关文章
- delphi中的idhttpserver如何才能收到idhttp发送来的exe\rar文件呢
http://zhidao.baidu.com/link?url=-q2oXqYCKBZ9OgFDEHAcQwQEY_NroHcqGvVfKW67X5sF9LdjAAB_HPXQo04VxStFVS7 ...
- Python中,添加写入数据到已经存在的Excel的xls文件,即打开excel文件,写入新数据
背景 Python中,想要打开已经存在的excel的xls文件,然后在最后新的一行的数据. 折腾过程 1.找到了参考资料: writing to existing workbook using xlw ...
- Android将日志信息自动发送到指定的邮箱中 邮件的内容以附件形式发送
今日整合了网上一些大神的例子(具体看了那些大神的?这个真不好意思我忘记了.下次再整合一定给大家补上,这次也只有默默的给那几个大神说声抱歉了.)做了一个“记录android项目中的日志信息,并将日志信息 ...
- idel 中 生成 jar包 和项目中自己需要的包
一.首先在自己的项目中创建一个类类中创建一个构造方法构造方法中传入一个字符串参数(这个字符串参数是为了传入路径) 在方法体内通过file类创建文件夹(换而言之就是项目中的包) 二 .就是对这个项目中的 ...
- 怎样在 Azure 应用服务中生成和部署 Java API 应用
先决条件 Java 开发人员工具包 8(或更高版本) 已在开发计算机上安装 Maven 已在开发计算机上安装 Git Azure 订阅付费版或试用版 HTTP 测试应用程序,如 Postman 使用 ...
- EBS OAF中如何在多行表中实现附件功能
EBS OAF中如何在多行表中实现附件功能 (版权声明,本人原创或者翻译的文章如需转载,如转载用于个人学习,请注明出处:否则请与本人联系,违者必究) 在OAF中使用附件功能之前,要先明白Entity( ...
- 内卷时代下的前端技术-使用JavaScript在浏览器中生成PDF文档
背景 在计量领域中,计量检定是一种重要形式,主要用于评定计量器具的计量性能,确定其量值是否准确一致,实现手段包括计量检验.出具检定证书和加封盖印等. 在检定证书这一环节,存在一个难点,就是无法在线预览 ...
- 如何在高并发分布式系统中生成全局唯一Id
月整理出来,有兴趣的园友可以关注下我的博客. 分享原由,最近公司用到,并且在找最合适的方案,希望大家多参与讨论和提出新方案.我和我的小伙伴们也讨论了这个主题,我受益匪浅啊…… 博文示例: 1. ...
- C# 在Word文档中生成条形码
C# 在Word文档中生成条形码 简介 条形码是由多个不同的空白和黑条按照一定的顺序组成,用于表示各种信息如产品名称.制造商.类别.价格等.目前,条形码在我们的日常生活中有着很广泛的应用,不管是在图书 ...
随机推荐
- 企业级NGINX的重定向rewrite
vim /usr/local/nginx/conf/nginx.conf server { listen 80; server_name www.ftl.com; rewrite ^/(.*) htt ...
- 微服务、rest/restful、springmvc、http简要梳理
微服务简介 微服务是一个新兴的软件架构,就是把一个大型的单个应用程序和服务拆分为数十个的支持微服务.一个微服务的策略可以让工作变得更为简便,它可扩展单个组件而不是整个的应用程序.简而言之,微服务架构是 ...
- Redis 拒绝连接
1.本地防火墙是否关闭 2.服务器的防火墙是否关闭 检查方法: service iptables status 查看防火墙状态 service iptables s ...
- GTK+开发环境搭建
GTK+开发环境搭建 "工欲善其事,必先利其器"首先介绍一下GTK+开发环境的搭建,网上很多所谓的GTK的开发环境的搭建基本都是抄来抄去,也不知道有没有人使用他们介绍的方法搭建并编 ...
- 利用TLE数据确定卫星轨道(2)-SGP4模型实现
1.TLE轨道报: 接上一篇,TLE轨道报各项内容所代表的意义如下: 2.SGP4模型: TLE轨道报计算卫星轨道需要用到 NORAD 开 发 的 SGP4/SDP4 模 型 ,SGP4模型是由 Ke ...
- A blog about Core Animation and other iOS graphics framework
A blog about Core Animation and other iOS graphics frameworks. https://www.calayer.com/
- socket的双重属性
1)api属性: 2)通信链路的端点属性.
- Kali-linux使用Easy-Creds工具攻击无线网络
Easy-Creds是一个菜单式的破解工具.该工具允许用户打开一个无线网卡,并能实现一个无线接入点攻击平台.Easy-Creds可以创建一个欺骗访问点,并作为一个中间人攻击类型运行,进而分析用户的数据 ...
- geomesa hbase geoserver
在geoserver中配置hbase ln -s /root/hbase/hbase-1.4.8/conf/hbase-site.xml /root/tomcat/apache-tomcat-7.0. ...
- CSS3 - 新单位vw、vh、vmin、vmax使用详解(附样例)
像 px.em 这样的长度单位大家肯定都很熟悉,前者为绝对单位,后者为相对单位.CSS3 又引入了新单位:vw.vh.vmin.vmax.下面对它们做个详细介绍. 一.基本说明 1,vw.vh.vmi ...