`

excell导入导出

    博客分类:
  • RUBY
阅读更多
部分代码:
module FileHandle
  extend ActiveSupport::Concern
  #Roo::Spreadsheet 直接读取文件导入
  module ClassMethods
    def import_data(file,current_user)
      imports = { failed: []}
      messages = {color:"#ff0000"}
      unless file.blank?
        orig_name = file.original_filename
        if ".XLSX" == File.extname(orig_name).upcase
          require 'roo'
          @students = []
          path = file.tempfile.path
          workbook = Roo::Spreadsheet.open path
          worksheet = workbook.sheet(0)
          row_no = 1
          worksheet.each_row_streaming(offset: 1, pad_cells: true) do |row|
            row_no += 1
            next if row[0].blank?
            record = {excel_row: row_no, success: true}
            self::IMPORT_COLUMNS.each do |c,i|
              record[c] = row[i]&.value 
            end
            return_student, message = self.save_from_hash(record, current_user)
            @students << return_student
            if return_student.blank?
              record[:success] = false
              record[:message] = message
              imports[:failed] << record 
            end
          end
          if imports == { failed: [] }
            messages[:color] = "#00DD00"
            messages[:detail] = "导入成功"
          end  
        else
          messages[:detail] = "文件格式要求为.xlsx格式。"
        end  
      else
        messages[:detail] = "请上传文件"
      end

      [imports,messages]
    end

   # 使用固定模版文件导出
    def export_data
      file = Spreadsheet.open "#{Rails.root}/public/xls/#{self.table_name}.xls"
      list = file.worksheet  0
      self.all.each_with_index do |r,index|
        self::EXPORT_COLUMN.each do |k,v|
          k = k.to_s
          list[index+1,v] = k.include?('|') ? r.send(k.split('|').first)&.send(k.split('|').last) : r.send(k)
        end
      end
      xls_report = StringIO.new
      file.write xls_report
      return xls_report.string
    end
  end  
end


源码参考:
https://github.com/jamst/tool-node/blob/master/excell_to_email
0
1
分享到:
评论
2 楼 小楠人 2017-06-09  
laoguan123 写道
楼主好,使用过一些excel导入导出的工具类,但是发现占据内存和cpu特别大的资源,可否指教一下怎么选择一个好的,节省资源的方法?

1 楼 laoguan123 2017-06-08  
楼主好,使用过一些excel导入导出的工具类,但是发现占据内存和cpu特别大的资源,可否指教一下怎么选择一个好的,节省资源的方法?

相关推荐

    asp将EXCEL导入导出数据库原程序

    这个"asp将EXCEL导入导出数据库原程序"提供了一个解决方案,能够方便地将Excel中的数据存入MSSQL数据库,同时也能将数据库中的数据导出到Excel文件。 首先,我们需要了解如何使用ASP连接MSSQL数据库。通常,这涉及...

    Thinkphp5整合excel导入导出

    Thinkphp5整合excel导入导出Thinkphp5整合excel导入导出Thinkphp5整合excel导入导出Thinkphp5整合excel导入导出Thinkphp5整合excel导入导出Thinkphp5整合excel导入导出Thinkphp5整合excel导入导出Thinkphp5整合excel...

    Excel导入导出项目 简单的

    Excel导入导出Excel导入导出Excel导入导出Excel导入导出Excel导入导出Excel导入导出Excel导入导出Excel导入导出Excel导入导出Excel导入导出Excel导入导出Excel导入导出

    java_poi实现excel导入导出

    Java POI 实现 Excel 导入导出 Java POI 是一个流行的 Java 库,用于处理 Microsoft Office 文件格式,包括 Excel 文件。在本文中,我们将详细介绍如何使用 Java POI 实现 Excel 导入导出功能。 1. 什么是 Java ...

    thinkhphp3.2 excel导入导出demo

    thinkhphp3.2 excel导入导出demothinkhphp3.2 excel导入导出demothinkhphp3.2 excel导入导出demothinkhphp3.2 excel导入导出demothinkhphp3.2 excel导入导出demothinkhphp3.2 excel导入导出demothinkhphp3.2 excel...

    Java POI EXCEL导入导出

    Java POI EXCEL导入导出Java POI EXCEL导入导出Java POI EXCEL导入导出Java POI EXCEL导入导出Java POI EXCEL导入导出Java POI EXCEL导入导出Java POI EXCEL导入导出Java POI EXCEL导入导出Java POI EXCEL导入导出...

    excel导入导出性能优化

    在IT行业中,Excel导入导出性能优化是一个常见且重要的议题,尤其对于处理大量数据的应用程序。Excel文件格式广泛用于数据存储和分析,但其导入和导出操作可能会对系统性能产生显著影响,尤其是在高并发环境下。以下...

    Excel导入导出工具包

    万能的Excel导入导出工具. 支持从List中导出. 支持从List中导入导出. 支持从List里面还有List&lt;POJO&gt;&gt;中导入导出. 支持导出类似课程表结构类型纵表. 支持国际化. 支持数据字典. 支持单元格中下拉框数据校验. 支持自动...

    excel 导入导出插件

    Excel导入导出插件是一种工具,它扩展了Excel的功能,使得用户能够方便地从电子表格中导入数据到其他系统,或者从外部数据源导出数据到Excel进行分析和处理。这种插件通常用于数据迁移、数据整合或数据分析,特别是...

    Excel导入导出封装

    针对Office 2003和Office 2007版本的Excel导入导出功能,开发者通常需要编写特定的代码来实现自动化操作。"Excel导入导出封装"是一个专门解决这一问题的测试类库,旨在简化这一过程,提高开发效率。 首先,我们要...

    Excel 导入导出 (asp.net/c#)

    标题"Excel 导入导出 (asp.net/c#)"所涉及的核心知识点主要包括Excel文件操作、C#编程以及ASP.NET web应用程序开发。下面我们将详细探讨这些主题。 1. **Excel文件操作**: - **Microsoft.Office.Interop.Excel**:...

    Java实现Excel导入导出

    Excel源代码,导入导出各种工具类 &lt;groupId&gt;org.apache.poi &lt;artifactId&gt;poi &lt;groupId&gt;org.apache.poi &lt;artifactId&gt;poi-scratchpad 代码实例: String path = ""; byte[] bytes; vo.setCurrentPage(0); vo....

    C# Excel 导入导出

    Excel导入导出是常见的需求,例如数据处理、报表生成和数据分析等。本篇文章将详细探讨C#如何实现Excel的导入导出功能。 首先,我们需要知道在C#中操作Excel有两种主要方式:一是使用Microsoft.Office.Interop....

    Excel导入导出

    在提供的压缩包文件中,可能包含已经封装好的方法和DLL,这些预封装的方法简化了Excel导入导出的过程,使得开发者可以直接调用,而无需关心底层的实现细节。这通常会提高开发效率,减少错误,并且便于代码维护。 ...

    普元导入导出用于Excel导入导出

    "普元导入导出"是普元信息公司提供的一个功能模块,主要应用于数据的批量导入与导出,尤其适用于与Excel文件的交互。这个功能在数据管理、数据分析以及日常业务处理中十分常见,因为它能够方便地将大量结构化数据在...

    Struts2 Excel导入导出数据

    在处理数据导入导出方面,Struts2提供了强大的支持,特别是与Excel文件的交互。本教程将深入探讨如何利用Struts2实现从Oracle数据库导出数据到Excel,以及如何将Excel文件中的数据导入到Oracle。 首先,我们需要...

    Java实现Excel导入导出操作详解.pptx.pptx

    Java实现Excel导入导出是Java开发中常见的任务,主要用于数据的批量处理和分析,尤其在数据分析、报表生成和数据备份等方面具有广泛应用。要熟练掌握这一技术,开发者需要了解Excel文件的结构,熟悉Java的文件操作,...

    Excel导入导出 jxl及Poi 工具类

    在Java开发中,处理Excel数据是一项常见的任务,无论是读取大量数据进行分析,还是批量导入导出信息。这里我们关注的是两个主要的库:jxl和Apache POI,它们都是用于处理Excel文件的强大工具。 首先,让我们深入...

    Java实现Excel导入导出功能

    在Java编程领域,实现Excel的导入导出功能是一项常见的任务,尤其在数据分析、报表生成以及数据交换等场景中。本文将深入探讨如何使用Java来处理Excel文件,包括读取、写入以及转换Excel数据。 首先,Java实现Excel...

Global site tag (gtag.js) - Google Analytics