Создание PDF из Rails
на Ruby On Rails Wiki перечисляет пару библиотекs, которые облегчают PDF поколения в рейлинги. Мне нужно распечатать адресные метки (в формате письма, таким образом, 12-15 адресов на страницу) и не могу решить, какой из них использовать. Есть рекомендации?
10 ответов
креветка с Prawnto наверняка. DSL-это настоящее удовольствие, как и простота обработки PDF как любого другого формата в блоке формата respond_to:
respond_to do |format|
format.pdf { render :layout => false }
есть учебное видео по креветкам здесь:
там же rtex управления. Это хорошо работает, если вы готовы перевести к латекс первый. LaTeX-очень хороший способ хранения размеченных документов. Это зависит от того, насколько статичен каждый документ. Если большая часть документа динамична, вы можете лучше использовать Prawn или PDF::Writer. Если большая часть из них статична, с парой текстовых замен для каждого, LaTeX может быть лучшим выбором.
Если вы не делаете ничего слишком сложного, вы также можете использовать HTMLDOC, который преобразует базовый HTML в PDF. Это не позволяет вам изучать более собственный синтаксис макета (например, в случае креветки). Это может сэкономить вам головные боли:)
вот ссылка на рубиновый камень для HTMLDOC:
кроме того, вот хорошее руководство для рендеринга представления в rails в pdf с помощью Свойстве htmldoc:
Я использовал как PDF:: Writer, так и Prawn и нашел креветку гораздо более приятной в использовании. Проверьте Рубин Нищий на сравнение это демонстрирует радости креветки w/r / T PDF::Writer.
на самом деле, просто проверьте Ruby Mendicant в любом случае для большой шаблон для правильного существования в качестве разработчика.
креветки-это путь. Теперь с креветками-ярлыками это действительно легко сделать.
Проверьте README проекта здесь:
https://github.com/jordanbyron/prawn-labels#readme
это супер простой пример, используемый в контроллере 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"
хотя и не полностью ruby, вы можете использовать OpenOffice .odt для создания PDF-файлов путем объединения serenity и docsplit.
http://github.com/kremso/serenity
http://documentcloud.github.com/docsplit/
или вы можете использовать clamsy gem, который использует odt и cups-pdf для создания PDF.
в любом случае, я согласен с большинством ответов, что prawn
правильный выбор, потому что вам нужен контроль уровня пикселей над выходом.
для создания PDF-отчетов со встроенным (opinionated) стилем таблицы, заголовками и т. д. вы можете использовать report
gem-проверить создать pdf из Rails 3-Какой инструмент выбрать? для примера использования.
я использовал летающую тарелку для генерации pdf из html. Это библиотека java, но вы можете использовать Ruby-Java Bridge gem для доступа к ней в приложении rails. Он совместим с css 2.1 и имеет несколько дополнений от css3, чтобы обеспечить дополнительный контроль над подкачкой. Я бы рекомендовал его, поскольку он не требует, чтобы вы помещали "pdf-код" в свой html, вы можете использовать те же представления и частичные файлы для отображения в браузере, что и для создания PDF-файлов.
Летающая Тарелка: https://github.com/flyingsaucerproject/flyingsaucer
Рубиновый Java-Мост: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/" + + '"' } # re-route absolute paths
html_string.gsub!( /url\(["']+([^:]+?)["']/i ) { |m| "url\(\"file:///#{RAILS_ROOT}/public/" + + '"' } # 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="' + .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