欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用Aspose.Cells實(shí)現(xiàn)導(dǎo)入導(dǎo)出

 更新時(shí)間:2018年12月13日 14:07:05   作者:HI阡陌  
這篇文章主要為大家詳細(xì)介紹了如何使用Aspose.Cells實(shí)現(xiàn)導(dǎo)入導(dǎo)出,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了Aspose.Cells實(shí)現(xiàn)導(dǎo)入導(dǎo)出的具體代碼,供大家參考,具體內(nèi)容如下

這是自己整理的導(dǎo)入導(dǎo)出類,里面有注釋。

using System;
using System.Collections.Generic;
using System.Data;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Aspose.Cells;
namespace Lzd.Mvc.EasyUi.Common.ExcelUtil
{
  /// 
  /// excel操作基類
  /// 
  /// 
 public  class BaseExcelUtil
  {
    private Workbook m_Wb = null;
 
  
 
    /// 
    /// 生成Excel
    /// 
    /// 模板Excel的路徑+文件名
    /// Excel文件的字節(jié)對象
    public byte[] CreateExcel(string url)
    {
      FileStream fs = null;
      try
      {
        //讀取模板Excel文件的中內(nèi)容
        fs = new FileStream(url, FileMode.Open, FileAccess.Read, FileShare.Read);
 
        m_Wb = new Workbook();
 
        m_Wb.Open(fs);
 
        setValue(m_Wb);
 
        //轉(zhuǎn)換為字節(jié)對象并返回
        return m_Wb.SaveToStream().ToArray();
 
      }
      catch (Exception ex)
      {
        throw ex;
      }
      finally
      {
        fs.Close();
      }
    }
 
 
    /// 
    /// 設(shè)定Excel中的數(shù)據(jù) 
    /// 數(shù)據(jù)源為datable類型
    /// 
    /// 工作簿
    public virtual void setValue(Workbook wb)
    {
      throw new Exception("The method or operation is not implemented.");
    }
    
   
 
 
    /// 
    /// 讀取Excel
    /// 
    /// Excel的路徑+文件名
    /// Excel文件的字節(jié)對象
    public DataTable GetExcel(string url)
    {
      FileStream fs = null;
      try
      {
        //讀取Excel文件的中內(nèi)容
        fs = new FileStream(url, FileMode.Open, FileAccess.Read, FileShare.Read);
 
        m_Wb = new Workbook();
 
        m_Wb.Open(fs);
 
        //設(shè)定Excel中的數(shù)據(jù)
       return  getValue(m_Wb);
 
      }
      finally
      {
        fs.Close();
      }
    }
 
    /// 
    /// 取得Excel中的數(shù)據(jù)
    /// 
    /// 工作簿
    public virtual DataTable getValue(Workbook wb)
    {
      throw new Exception("The method or operation is not implemented.");
    }
    /// 
    /// 設(shè)置字符串值
    /// 
    /// 
    /// 
    public void putValue(Cell c, object value)
    {
      try
      {
        if (value == null || object.Equals(value, DBNull.Value) || value.ToString().Trim().Length == 0)
        {
 
        }
        else
        {
          c.PutValue(value.ToString());
        }
      }
      catch (Exception)
      {
        c.PutValue("--");
      }
    }
    /// 
    /// 設(shè)置數(shù)值值
    /// 
    /// 
    /// 
    public void putValueDouble(Cell c, object value)
    {
      try
      {
        if (value == null || object.Equals(value, DBNull.Value) || value.ToString().Trim().Length == 0)
        {
 
        }
        else
        {
          c.PutValue(Decimal.Parse(value.ToString()));
        }
      }
      catch (Exception)
      {
        c.PutValue(value.ToString());
      }
    }
    /// 
    /// 設(shè)置日期值
    /// 
    /// 
    /// 
    public void putDateValue(Cell c, object value)
    {
      try
      {
        if (value == null || object.Equals(value, DBNull.Value) || value.ToString().Trim().Length == 0)
        {
 
        }
        else
        {
          c.PutValue(DateTime.Parse(value.ToString()));
        }
      }
      catch (Exception)
      {
        c.PutValue(value.ToString());
      }
    }
 
 
  }
  
}

////實(shí)現(xiàn)基類 

using System;
using System.Collections.Generic;
using System.Data;
using System.Linq;
using System.Reflection;
using System.Text;
using System.Threading.Tasks;
using Aspose.Cells;
namespace Lzd.Mvc.EasyUi.Common.ExcelUtil
{
  /// 
  /// Excel幫助類
  /// 
  public class ExcelUtil :BaseExcelUtil
  {
    private DataTable dt;
    private string title;
   
    public ExcelUtil() {
      
 
    }
 
    /// 
    /// 從第幾行開始讀取
    /// 
    public int FirstRow { get; set; }
    /// 
    /// 從第幾列開始讀取
    /// 
    public int FirstColumns { get; set; }
 
    /// 
    /// excel標(biāo)題
    /// 
    public string Title
    {
      get { return title; }
      set { title = value; }
    }
    private string fileName;
 
    /// 
    /// 文件名
    /// 
    public string FileName
    {
      get { return fileName; }
      set { fileName = value; }
    }
 
    public DataTable Dt
    {
      get { return dt; }
      set { dt = value; }
    }
 
    public bool Flag
    {
      set;
      get;
    }
   ///
   ///
   ///導(dǎo)出設(shè)定值
    public override void setValue(Workbook wb)
    {
      
      int index = 0;
      Worksheet ws = null;
      int rcount = dt.Rows.Count, columns = dt.Columns.Count;
      if (dt != null && dt.Rows.Count > 0)
      {
        index = wb.Worksheets.AddCopy(0);
        ws = wb.Worksheets[index];
        ws.Name = FileName.Replace(".xls", "");
 
        try
        {
          putValue(ws.Cells[0, 0], this.title);
          int i = 1;
 
          for (int j = 0; j < columns; j++)
          {
 
            putValue(ws.Cells[1, j], dt.Columns[j].ColumnName);
          }
 
          for (int j = 0; j < rcount; j++)
          {
            i++;
            for (int h = 0; h < columns; h++)
            {
 
              putValue(ws.Cells[i, h], dt.Rows[j][h].ToString());
            }
 
          }
 
          wb.Worksheets.RemoveAt(0);
        }
        catch (Exception ex)
        {
          throw ex;
        }
      }
    }
 
    /// 
    /// 導(dǎo)入excel
    /// 
    /// 讀取的文件名
    /// 從第幾行開始讀取
    /// 從第幾列開始讀取
    /// 
    /// 
 
    public override DataTable getValue(Workbook wb)
    {
    
      Worksheet sheet = wb.Worksheets[0];
      Cells cells = sheet.Cells;
 
      return cells.ExportDataTableAsString(FirstRow, FirstColumns, cells.MaxDataRow + 1, cells.MaxDataColumn + 1, true);
    }
 
    
 
 
 
  }
 
}

/////導(dǎo)出調(diào)用方法

public ActionResult ToExcel() {
      List list = new List();
      for (int i = 0; i < 100; i++)
      {
        UserInfo info = new UserInfo();
        info.Age = i.ToString();
        info.ID = i;
        info.Name = "姓名" + i;
        list.Add(info);
      }
      ///將list類型轉(zhuǎn)換為datatable
      DataTable dt= DataTableHelper.IListToDataTable(list);
      //實(shí)例化幫助類
      ExcelUtil exc = new ExcelUtil();
      exc.Dt = dt;
      exc.FileName = "導(dǎo)出測試.xls";
      exc.Title = "導(dǎo)出測試";
      //需要寫入的模板
      string url = Server.MapPath("/Content/Down/template.xls");
      byte[] data = exc.CreateExcel(url);
      //瀏覽器下載文件
      Response.AppendHeader("Content-Disposition", "attachment; filename=" + exc.FileName);//HttpUtility.UrlEncode(r.FileName, Encoding.UTF8));
      Response.ContentType = "application/ms-excel";
      Response.AddHeader("Content-Length", data.Length.ToString());
      Response.ContentEncoding = System.Text.Encoding.GetEncoding("UTF-8");
      Response.BinaryWrite(data);
      System.Web.HttpContext.Current.ApplicationInstance.CompleteRequest();
      return Content("ss");
    }

///導(dǎo)入調(diào)用方法

public ActionResult ImportExcel()
    {
      string url = Server.MapPath("/Content/Down/Import.xls");
      ExcelUtil exc = new ExcelUtil();
      exc.FirstRow = 1;
      exc.FirstColumns = 0;
       DataTable dt= exc.GetExcel(url);
      
   
 
      return Content("ss");
    }

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • asp.net 生成靜態(tài)頁時(shí)的進(jìn)度條顯示

    asp.net 生成靜態(tài)頁時(shí)的進(jìn)度條顯示

    本文側(cè)重點(diǎn)在講解生成靜態(tài)頁的“進(jìn)度條”,所以將采用模擬的方法。生成靜態(tài)時(shí)需要生成的文章必須非常多,否則進(jìn)度條可能一閃而過,看不到效果。
    2009-05-05
  • .net中as和is之間的區(qū)別分析

    .net中as和is之間的區(qū)別分析

    .net中as和is之間的區(qū)別分析,需要的朋友可以參考一下
    2013-05-05
  • APS.NET MVC4生成二維碼簡單解析

    APS.NET MVC4生成二維碼簡單解析

    這篇文章主要介紹了APS.NET MVC4二維碼的生成過程,需要的朋友可以參考下
    2015-11-11
  • 如何使用Rotativa在ASP.NET Core MVC中創(chuàng)建PDF詳解

    如何使用Rotativa在ASP.NET Core MVC中創(chuàng)建PDF詳解

    這篇文章主要給大家介紹了關(guān)于如何使用Rotativa在ASP.NET Core MVC中創(chuàng)建PDF的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-02-02
  • asp.net類庫中添加WebService引用出現(xiàn)問題解決方法

    asp.net類庫中添加WebService引用出現(xiàn)問題解決方法

    在Web項(xiàng)目內(nèi)添加WebService的引用是件很簡單的事情,不過對于一些新手朋友來說,就沒有那么簡單了,因?yàn)樵谔砑拥倪^程中總會(huì)遇到一些困難,接下來詳細(xì)介紹如何解決,感興趣的你可不要錯(cuò)過了啊
    2013-02-02
  • Asp.Net Core WebAPI使用Swagger時(shí)API隱藏和分組詳解

    Asp.Net Core WebAPI使用Swagger時(shí)API隱藏和分組詳解

    這篇文章主要給大家介紹了關(guān)于Asp.Net Core WebAPI使用Swagger時(shí)API隱藏和分組的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用Asp.Net Core具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • 攔截asp.net輸出流并進(jìn)行處理的方法

    攔截asp.net輸出流并進(jìn)行處理的方法

    這篇文章主要介紹了攔截asp.net輸出流并進(jìn)行處理的方法,比較有實(shí)用性的一個(gè)技巧,需要的朋友可以參考下
    2014-08-08
  • .net發(fā)送郵件實(shí)現(xiàn)代碼

    .net發(fā)送郵件實(shí)現(xiàn)代碼

    代碼基本上可以實(shí)現(xiàn)郵件的發(fā)送,但是在測試時(shí)卻在 smtp.Send(objMail);處顯示“發(fā)送郵件失敗”,最后發(fā)現(xiàn)的問題是,我的殺毒軟件對郵件發(fā)送接收進(jìn)行了保護(hù),只需去掉保護(hù)就能夠發(fā)送成功了。
    2009-02-02
  • ASP.NET Core使用Log4net實(shí)現(xiàn)日志記錄功能

    ASP.NET Core使用Log4net實(shí)現(xiàn)日志記錄功能

    這篇文章介紹了ASP.NET Core使用Log4net實(shí)現(xiàn)日志記錄功能的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-03-03
  • 在ASP.NET Core5.0中訪問HttpContext的方法步驟

    在ASP.NET Core5.0中訪問HttpContext的方法步驟

    這篇文章主要介紹了在ASP.NET Core5.0中訪問HttpContext的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11

最新評論