Создать PDF из Rails
В Ruby On Rails Wiki перечислено несколько библиотек, которые облегчают генерацию PDF в Rails. Мне нужно распечатать адресные этикетки (в буквенном формате, таким образом, 12-15 адресов на страницу) и не могу решить, какой из них использовать. Любые рекомендации?
10 ответов
Лучшее, что я видел до сих пор, это креветка:
Креветка с Prawnto точно. DSL - реальное удовольствие, так же как и простота возможности обрабатывать PDF как любой другой формат в блоке формата response_to:
respond_to do |format|
format.pdf { render :layout => false }
Здесь есть обучающее видео по креветкам:
Там также RTeX. Это хорошо работает, если вы хотите сначала перевести на LaTeX. LaTeX - очень хороший способ хранения размеченных документов. Это зависит только от того, насколько статичен каждый документ. Если большая часть документа является динамической, вы можете лучше использовать Prawn или PDF::Writer. Если большинство из них статические, с несколькими заменами текста для каждого, LaTeX может быть лучшим выбором.
Креветка - это путь. Теперь с этикетками креветок это действительно легко сделать.
Проверьте README проекта здесь:
https://github.com/jordanbyron/prawn-labels
Это очень простой пример, используемый в контроллере Rails. Не забудьте добавить gem 'prawn-labels'
в ваш Gemfile.
names = %w{Jordan Kelly Greg Bob}
labels = Prawn::Labels.render(names, :type => "Avery5160") do |pdf, name|
pdf.text name
end
send_data labels, :filename => "names.pdf", :type => "application/pdf"
Если вы не делаете ничего слишком сложного, вы также можете использовать HTMLDOC, который преобразует основной HTML в PDF. Это избавляет вас от необходимости изучать собственный синтаксис макета (как в случае с Prawn). Это может избавить вас от головной боли:)
Вот ссылка на гем ruby для HTMLDOC:
Также, вот хорошее руководство для рендеринга представления в rails в pdf с использованием HTMLDOC:
Я использовал PDF::Writer и Prawn и считаю Prawn гораздо более приятным в использовании. Проверьте Ruby Mendicant для сравнения, которое демонстрирует радости Prawn w/r/t PDF::Writer.
На самом деле, просто проверьте Ruby Mendicant на отличный шаблон дизайна для правильной жизни разработчика.
Для вашего случая использования я согласен с большинством других ответов, которые prawn
это правильный выбор, потому что вам нужен контроль на уровне пикселей на выходе.
Для генерации отчетов в формате PDF со встроенным (упорядоченным) стилем таблицы, заголовками и т. Д. Вы можете использовать report
gem - проверить Создать PDF из Rails 3 - какой инструмент выбрать? для примера того, как использовать.
Я использовал летающую тарелку для генерации PDF из HTML. Это библиотека Java, но вы можете использовать гем Ruby-Java Bridge для доступа к нему в вашем приложении rails. Он совместим с css 2.1 и имеет несколько дополнений из css3, чтобы обеспечить дополнительный контроль над подкачкой. Я бы порекомендовал его, так как он не требует, чтобы вы добавили "pdf code" в ваш html, вы можете использовать те же представления и частичные значения для отображения в браузере, что и для создания pdf.
Летающая тарелка: https://github.com/flyingsaucerproject/flyingsaucer
Ruby Java Bridge: http://rjb.rubyforge.org/
Я использую этот код модуля для создания PDF-файлов
require 'rubygems'
require 'rjb'
module Html2Pdf
def self.included(controller)
controller.send :helper_method, :create_pdf
end
def create_pdf(options = {})
itext = "#{RAILS_ROOT}/lib/html2pdf/jars/iText-2.0.8.jar"
core_renderer = "#{RAILS_ROOT}/lib/html2pdf/jars/core-renderer.jar"
xerces = "#{RAILS_ROOT}/lib/html2pdf/jars/xml-apis-xerces-2.9.1.jar"
joinchar = (RUBY_PLATFORM.include? 'mswin') ? ';' : ':'
classpath = [itext, core_renderer, xerces].join(joinchar)
Rjb::load(classpath, jvmargs=['-Djava.awt.headless=true'])
if options[:htmlstring].nil?
options[:layout] ||= false
options[:template] ||= File.join(controller_path,action_name+".pdf.erb")
html_string = render_to_string(:template => options[:template], :layout => options[:layout])
else
html_string = options[:htmlstring]
end
# Make all paths relative, on disk paths...
html_string.gsub!(".com:/",".com/") # strip out bad attachment_fu URLs
html_string.gsub!( /src=["']+([^:]+?)["']/i ) { |m| "src=\"file:///#{RAILS_ROOT}/public/" + $1 + '"' } # re-route absolute paths
html_string.gsub!( /url\(["']+([^:]+?)["']/i ) { |m| "url\(\"file:///#{RAILS_ROOT}/public/" + $1 + '"' } # re-route absolute paths
# Remove asset ids on images with a regex // tbh i can't remember what this line is for but i'm sure it did something awesome
html_string.gsub!( /src=["'](\S+\?\d*)["']/i ) { |m| 'src="' + $1.split('?').first + '"' }
filename = "#{RAILS_ROOT}/public/pdfs/"+options[:filename]+".pdf"
fileOutputStream = Rjb::import('java.io.FileOutputStream')
iTextRenderer = Rjb::import('org.xhtmlrenderer.pdf.ITextRenderer')
renderer = iTextRenderer.new
renderer.setDocumentFromString(html_string)
os = fileOutputStream.new(filename)
renderer.layout()
renderer.createPDF(os)
os.close()
end
end
Вызывая это с кодом как это:
def generate_pdf
htmlsrc = render_to_string(:partial => 'invoice', :layout => false)
rnd = Time.now.to_s(:datentime).gsub!(/[\/ \.:]/,'')
filename = "docstore/tmp_#{rnd}"
create_pdf(:htmlstring => htmlsrc, :filename => filename)
contents = open("#{RAILS_ROOT}/public/pdfs/#{filename}.pdf", "rb") { |io| io.read }
File.delete("#{RAILS_ROOT}/public/pdfs/#{filename}.pdf")
respond_to do | wants |
wants.html { render :text => contents, :content_type => 'application/pdf' }
end
end
Хотя это и не совсем ruby, вы можете использовать OpenOffice .odt для создания PDF-файлов, сочетая спокойствие и docsplit.
http://github.com/kremso/serenity
http://documentcloud.github.com/docsplit/
Или вы можете использовать драгоценный камень, который использует odt и cups-pdf для создания PDF.