如何将我的视图表转换为excel格式

时间:2016-10-10 06:52:54

标签: mysql ruby-on-rails ruby excel ruby-on-rails-3

我是ruby on rails的新手,我想以excel格式导出我的视图表,我已经尝试了很多次但是我无法导出视图表。 我的数据库中有一个视图(Employee_Information),所有数据都显示在view.html.erb页面中,没有针对Employee_Information视图的特定模型。我已按照本教程" {{3但是我这个教程在模型的帮助下将数据导出到视图表中的excel,我想用模型。

**excel_file.html.erb**
`<table border=1>
  <tr>
    <th>Employee ID</th>
    <th>Name</th>
    <th>Gender</th>
    <th>Date of birth</th>
    <th>Email</th>
    <th>Marital status</th>
    <th>Father Name</th>
    <th>Spouse Name</th>
    <th>Contact</th>
    <th>Employee Address</th>
    <th>Account Number</th>
    <th>IFSC Code</th>
    <th>PAN Number</th>
    <th>Client Name</th>
    <th>Designation</th>
    <th>Employee Type</th>
    <th>Status</th>
    <th>Joining date</th>
    <th>End date</th>
    <th>Offer CTC</th>
    <th>Client Address</th>    
  </tr>
  <% @employees.each do |emp| %>   
    <tr>
       <th><%= emp['employee_id'] %></th>
        <th><%= emp['full_name'] %></th>
        <th><%= emp['gender'] %></th>
        <th><%= emp['dob_date'] %></th>
        <th><%= emp['email'] %></th>
        <th><%= emp['married_status'] %></th>
        <th> <%= emp['father_name'] %></th>
        <th><%= emp['spouse_name'] %></th>
        <th><%= emp['contact_phone'] %></th>
        <th><%= emp['candidate_address2'] %></th>
        <th><%= emp['bank_ac'] %></th>
        <th><%= emp['bank_ifsc'] %></th>
        <th><%= emp['pan_number'] %></th>
        <th><%= emp['company_name'] %></th>
        <th><%= emp['designation'] %></th>
        <th>
            <% if emp['employee_type'] == 0 %>
                Internal Employee
            <% elsif emp['employee_type'] == 1 || emp['employee_type'] == 2 || emp['employee_type'] == 3 %>
                Contract Consultant Employee
            <% elsif emp['employee_type'] == 4 %>
                Permanent Consultant Employee
            <% elseif emp['employee_type'] == 5 %>
                Past Employee
            <% end %> 
        </th>
        <th>
            <% if emp['status'] == 0 %>
                Pending
            <% elsif emp['status'] == 1 %>
                Approved
            <% elsif emp['status'] == 2 %>
                Cancelled
            <% elsif emp['status'] == 3 %>
                Accepted
            <% elsif emp['status'] == 4 %>
                Rejected
            <% elsif emp['status'] == 5 %>
                Onboarded
            <% elsif emp['status'] == 6 %>
                Offboarded
            <% end %> 
        </th>
        <th><%= emp['joining_date'] %></th>
        <th><%= emp['work_end_date'] %></th>
        <th><%= emp['ctc'] %></th>
        <th><%= emp['client_address2']%></th>  
    </tr>
  <% end %>  
</table>
<br><br>`

**hr_controller.rb**`def excel_file
        @employees = MysqlConnection.connection.select_all("SELECT * FROM         Employee_Information where employee_type IN(0)")
        #@employees = MysqlConnection.connection.select_all("SELECT * FROM Employee_Information where employee_type IN(1,2,3)")
        respond_to do |format|
            format.html
            format.csv { send_data @employees.to_csv }
        end
    end`
**application.rb**



  require File.expand_path('../boot', __FILE__)
     # add HR role
     require "csv"

我创建了一个文件模块&#34; employee_information.rb&#34;进入lib文件夹

  module EmployeeInformation    
      def self.to_csv(options = {})
        CSV.generate(options) do |csv|
            csv << column_names
            all.each do |product|
              csv << product.attributes.values_at(*column_names)
            end
        end
    end end

1 个答案:

答案 0 :(得分:0)

这是否必须是视图表?除非你使用某种形式,否则没有办法不使用javascript来解析DOM(或者更确切地说访问DOM中的所有元素)并获取值并使用解析后的信息向控制器发出请求DOM。如果您可以将其设置为某种提交形式,则可以更轻松地将此信息导出到Excel。无论哪种方式,没有其他方法可以用某种模型来做到这一点。