Создать PDF из Rails 3 - какой инструмент выбрать?
Мне нужно иметь возможность отображать некоторые представления в виде PDF-файлов из проекта Rails 3. Раньше я никогда не использовал методы генерации PDF с ruby /rails, поэтому я исследовал несколько популярных подходов, таких как Prawn и PDF:: Writer, но все примеры и статьи, которые я нашел, кажутся устаревшими и применимы только к rails 2.x, Я еще не видел работающего примера Rails3; Я попытался установить креветки и самоцветы prawnto и воспроизвести пример, описанный в этом эпизоде Railscasts, но я получаю ошибку, когда метод prawnto не распознается. Я не уверен, было ли это ошибкой реализации или просто признаком несовместимости, но, видя, как другие люди делятся в сети тем, что креветка больше не работает для них в Rails3, я не стал больше отслеживать код.
Кто-нибудь нашел работающее надежное решение для генерации PDF в Rails3? Не могли бы вы поделиться этим или указать мне на внешние ресурсы и документацию? Большое спасибо!
5 ответов
Новый ответ на старый вопрос, на случай, если другие наткнуться на это: WickedPDF (который использует wkhtmltopdf, как PDFkit) делает это несложно.
Prawn работает с Rails 3. Лично я использовал его без проблем. Вы должны получить последние версии драгоценного камня и плагин prawnto для рельсов.
PDFkit имеет то преимущество, что использует движок рендеринга Webkit, поэтому вы можете использовать CSS для определения макетов и бесплатно получать соответствующие веб-страницы с Safari и Chrome. У него немного более приятная кривая обучения, чем у Prawn.
Вы видели PDFkit? Я уверен, что это работает с Rails 3, это часть промежуточного программного обеспечения Rack, которое может конвертировать любую HTML-страницу в PDF, которая соответствует маршруту, заканчивающемуся в.pdf
Что касается креветок, вот плавная интеграция для Rails 3, которая, кажется, работает отлично: https://github.com/Whoops/prawn-rails
Вы можете использовать гем отчета, который генерирует PDF, а также XLSX и CSV.
# a fake Manufacturer class - you probably have an ActiveRecord model
Manufacturer = Struct.new(:name, :gsa)
require 'report'
class ManufacturerReport < Report
table 'Manufacturers' do # you can have multiple tables, which translate into multiple sheets in XLSX
head do
row 'Manufacturer report'
end
body do
rows :manufacturers
column 'Name', :name
column 'GSA?', :gsa
end
end
# you would want this so that you can pass in an array
# attr_reader :manufacturers
# def initialize(manufacturers)
# @manufacturers = manufacturers
# end
def manufacturers
[
Manufacturer.new('Ford', true),
Manufacturer.new('Fischer', false),
Manufacturer.new('Tesla', nil),
]
end
end
Когда вы звоните report.pdf.path
PDF создается в каталоге tmp:
report = ManufacturerReport.new
puts report.pdf.path #=> /tmp/185051406_Report__Pdf.pdf
puts report.xlsx.path #=> /tmp/185050541_Report__Xlsx.xlsx
Вы можете сделать это в вашем контроллере, как:
@manufacturers = Manufacturer.all
respond_to do |format|
format.html # index.html.erb
format.json { render json: @manufacturers }
format.pdf do
report = ManufacturerReport.new(@manufacturers) # using the commented-out code
send_file report.pdf.path, :type => 'application/pdf', :disposition => 'attachment', :filename => 'ManufacturersReport.pdf'
# tmp files are periodically cleaned up by the operating system, but if you want to be extra clean you can call
# report.cleanup
# but this may remove the tmp files before apache/nginx/etc. finishes delivering the file
end
end
Конечный результат:
XLSX
Обратите внимание, что в XLSX автоматически добавлен автофильтр.