Подтвердить что ты не робот

Rails - экспортировать записи в загружаемый файл excel с использованием драгоценного камня axlsx (Keep MVC)

Я успешно установил драгоценный камень axlsx из https://github.com/randym/axlsx Вот мой код контроллера, который я использовал для создания файла excel через этот камень.

Но ничего не происходит с этим кодом, вместо этого он показывает мне ошибку uninitialized mime

class Coaches::PaymentsController < ApplicationController

  before_filter :authenticate_coach!

  # List all the payments
  def index
    if !params[:sort].blank?
      @payments = Payment.includes(:member).paginate(:page => params[:page], :order => sort_column + " " + sort_direction)
    else
      @payments = Payment.includes(:member).paginate(:page => params[:page], :order=>'id desc')
    end
    respond_to do |format|
      format.html
      # Change format to xlsx
      format.xlsx
      format.json { render json: @payments }
    end
  end
end

Во-вторых, я пытаюсь использовать этот код:

wb = xlsx_package.workbook
wb.add_worksheet(name: "Buttons") do |sheet|
  @buttons.each do |button|
    sheet.add_row [button.name, button.category, button.price]
  end
end

Но, к сожалению, это не сработает. Может ли кто-нибудь сказать мне только намекнуть не на решение моей задачи?

Я пробовал третий раз в соответствии с предложением:

   def index
    if !params[:sort].blank?
      @payments = Payment.includes(:member).paginate(:page => params[:page], :order => sort_column + " " + sort_direction)
    else
      @payments = Payment.includes(:member).paginate(:page => params[:page], :order=>'id desc')
    end
    respond_to do |format|
      format.xlsx do
        p = Axlsx::Package.new
        wb = p.workbook
        wb.add_worksheet(name: "Your worksheet name") do |sheet|
          sheet.add_row ["First Column", "Second", "Third"]
          sheet.add_row [1, 2, 3]
          sheet.add_row [' preserving whitespace']
        end
        send_data p.to_stream.read, type: "application/xlsx", filename: "filename.xlsx"
      end
    end
  end

Он бросил мне ошибку http 406

4b9b3361

Ответ 1

Попробуйте использовать axlsx_rails Gem с шаблоном. В моем случае я использовал ниже конфигурацию, чтобы заставить ее работать. а также ссылку с расширением .xlsx, чтобы отобразить ее в формате xlsx.

GEM FILE

gem 'axlsx', '~> 2.0'
gem "axlsx_rails"

controller file- payments_controller.rb

def download
    @payments = Payment.all
    respond_to do |format| 
       format.xlsx {render xlsx: 'download',filename: "payments.xlsx"}
    end
end

Просмотреть файл- download.xlsx.axlsx

wb = xlsx_package.workbook
wb.add_worksheet(name: "Payments") do |sheet|
    sheet.add_row ["ID", "Notes","Amount($)","Deposit Date"]
    @payments.each do |payment|
        sheet.add_row [payment.id, payment.notes,payment.amount,payment.date_deposite]
    end
end

Ответ 2

Чтобы предотвратить ошибку неинициализированного типа mime, добавьте следующий файл:

# config/initializers/mime_types.rb

Mime::Type.register "application/xlsx", :xlsx

И вот краткий пример того, что делать, чтобы загрузить файл xlsx:

format.xlsx do
  p = Axlsx::Package.new
  wb = p.workbook
  wb.add_worksheet(name: "Your worksheet name") do |sheet|
    # Add your stuff
  end
  send_data p.to_stream.read, type: "application/xlsx", filename: "filename.xlsx"
end

Ответ 3

Установите рендеринг false в HTML и не используйте JSON вместо XLS и для трассировки, вы можете увидеть терминал, на котором вы запустили рельсы.

Ответ 4

gem 'axlsx', '~> 2.0'
gem "axlsx_rails"

Ответ 5

Я использую драгоценные камни.

gem 'axlsx', '~> 2.0'
gem "axlsx_rails"

Но у этих камней произошла ошибка. Когда я удаляю "rubyzip" gem из Gemfile.lock, проблема bundle install решена. Спасибо.