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

ASP.NET實(shí)現(xiàn)上傳Excel功能

 更新時(shí)間:2017年03月28日 14:26:55   作者:Michael我想念你  
本文主要介紹了ASP.NET 實(shí)現(xiàn)上傳EXCEL,利用NOPI操作,轉(zhuǎn)換得到DataTable的相關(guān)知識(shí)。具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧

這幾天正好用到上傳Excel,并根據(jù)Excel中的數(shù)據(jù)做相應(yīng)的處理,故整理以備用。

用到的資源:

(1)NOPI 2.2.0.0 可自己官網(wǎng)下載,也可點(diǎn)擊:http://pan.baidu.com/s/1b1EMdg

(2)用到一些常見(jiàn)處理文件的公共方法類,可以添加到項(xiàng)目中:http://pan.baidu.com/s/1bJpHuQ

如過(guò)上述連接因故無(wú)法使用,可在評(píng)論留下郵箱,我打包發(fā)送過(guò)去,如有更好的建議,歡迎指導(dǎo)。

后臺(tái)的提示方法ShowMsgHelper,根據(jù)自己的改寫(xiě)即可。

前臺(tái)代碼:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
 <title>導(dǎo)入EXCEL,生成DataTable</title>
 <script src="../../Themes/Scripts/jquery-1.8.2.min.js"></script>
 <link href="/Themes/Styles/Site.css" rel="external nofollow" rel="stylesheet" type="text/css" />
 <script src="/Themes/Scripts/FunctionJS.js" type="text/javascript"></script>
 
 <script type="text/javascript">
 $(document).ready(function () {
  $("#Import").click(function () {
  var filename = $("#FileUpload1").val();
  if (filename == '') {
   alert('請(qǐng)選擇上傳的EXCEL文件');
   return false;
  }
  else {
   var exec = (/[.]/.exec(filename)) ? /[^.]+$/.exec(filename.toLowerCase()) : '';
   if (!(exec == "xlsx" || exec == "xls")) {
   alert("文件格式不對(duì),請(qǐng)上傳Excel文件!");
   return false;
   }
  }
  return true;
  });
 });
 </script>
</head>
<body>
 <form id="form1" runat="server">
 <div>
 <asp:FileUpload ID="FileUpload1" runat="server" /><asp:Button ID="Import" runat="server" Text="導(dǎo)入" OnClick="ImpClick" />
 </div>
 </form>
</body>
</html>

后臺(tái)代碼;

protected void ImpClick(object sender, EventArgs e)
 {
  try
  {
  #region 校驗(yàn)
  var fileName = this.FileUpload1.FileName;
  if (string.IsNullOrWhiteSpace(fileName))
  {
   //提示信息
   ShowMsgHelper.Alert("請(qǐng)選擇上傳Excel文件");
   return;
  }
  //獲取上傳文件擴(kuò)展名稱
  if (!(fileName.IndexOf(".xlsx") > 0 || fileName.IndexOf(".xls") > 0))
  {
   ShowMsgHelper.Alert("上傳文件格式不正確,請(qǐng)核對(duì)!");
   return;
  }
  #endregion
  #region 將Excel文件上傳到服務(wù)器上臨時(shí)文件夾中
  //臨時(shí)文件夾,根目錄下/Upload/tmp/,根據(jù)自己配置選擇
  string path = Server.MapPath("~/") + "Upload\\tmp\\";
  string retStr=UploadHelper.FileUpload(path, this.FileUpload1);
  if (!retStr.Equals("上傳成功")) {
   ShowMsgHelper.Alert(retStr);
   return;
  }
  #endregion
  #region 讀取Excel文件第一個(gè)表獲取內(nèi)容并轉(zhuǎn)換成DataTable,刪除臨時(shí)文件,也可以自己加時(shí)間戳,維護(hù)處理
  DataTable dt = this.ExcelToDataTable(path + this.FileUpload1.FileName, true);
  if (dt == null) {
   ShowMsgHelper.Alert_Error("獲取失敗");
   return;
  }
  //示例:獲取dt中的值
  string test = dt.Rows[0]["name"].ToString();
  string test2 = dt.Rows[1]["class"].ToString();
  //刪除臨時(shí)文件
  DirFileHelper.DeleteFile("Upload\\tmp\\" + fileName);
  #endregion 
  }
  catch (Exception ex) {
  throw ex;
  }
 }
 /// <summary>
 /// 將excel導(dǎo)入到datatable
 /// </summary>
 /// <param name="filePath">excel路徑</param>
 /// <param name="isColumnName">第一行是否是列名</param>
 /// <returns>返回datatable</returns>
 public DataTable ExcelToDataTable(string filePath, bool isColumnName)
 {
  DataTable dataTable = null;
  FileStream fs = null;
  DataColumn column = null;
  DataRow dataRow = null;
  IWorkbook workbook = null;
  ISheet sheet = null;
  IRow row = null;
  ICell cell = null;
  int startRow = 0;
  try
  {
  using (fs = File.OpenRead(filePath))
  {
   // 2007版本
   if (filePath.IndexOf(".xlsx") > 0)
   workbook = new XSSFWorkbook(fs);
   // 2003版本
   else if (filePath.IndexOf(".xls") > 0)
   workbook = new HSSFWorkbook(fs);
   if (workbook != null)
   {
   sheet = workbook.GetSheetAt(0);//讀取第一個(gè)sheet,當(dāng)然也可以循環(huán)讀取每個(gè)sheet
   dataTable = new DataTable();
   if (sheet != null)
   {
    int rowCount = sheet.LastRowNum;//總行數(shù)
    if (rowCount > 0)
    {
    IRow firstRow = sheet.GetRow(0);//第一行
    int cellCount = firstRow.LastCellNum;//列數(shù)

    //構(gòu)建datatable的列
    if (isColumnName)
    {
     startRow = 1;//如果第一行是列名,則從第二行開(kāi)始讀取
     for (int i = firstRow.FirstCellNum; i < cellCount; ++i)
     {
     cell = firstRow.GetCell(i);
     if (cell != null)
     {
      if (cell.StringCellValue != null)
      {
      column = new DataColumn(cell.StringCellValue);
      dataTable.Columns.Add(column);
      }
     }
     }
    }
    else
    {
     for (int i = firstRow.FirstCellNum; i < cellCount; ++i)
     {
     column = new DataColumn("column" + (i + 1));
     dataTable.Columns.Add(column);
     }
    }
    //填充行
    for (int i = startRow; i <= rowCount; ++i)
    {
     row = sheet.GetRow(i);
     if (row == null) continue;

     dataRow = dataTable.NewRow();
     for (int j = row.FirstCellNum; j < cellCount; ++j)
     {
     cell = row.GetCell(j);
     if (cell == null)
     {
      dataRow[j] = "";
     }
     else
     {
      //CellType(Unknown = -1,Numeric = 0,String = 1,Formula = 2,Blank = 3,Boolean = 4,Error = 5,)
      switch (cell.CellType)
      {
      case CellType.Blank:
       dataRow[j] = "";
       break;
      case CellType.Numeric:
       short format = cell.CellStyle.DataFormat;
       //對(duì)時(shí)間格式(2015.12.5、2015/12/5、2015-12-5等)的處理
       if (format == 14 || format == 31 || format == 57 || format == 58)
dataRow[j] = cell.DateCellValue;
else       dataRow[j] = cell.NumericCellValue;
break;
      case CellType.String:
dataRow[j] = cell.StringCellValue;
break;
      }
     }
     }
     dataTable.Rows.Add(dataRow);
    }
    }
   }
   }
  }
  return dataTable;
  }
  catch (Exception)
  {
  if (fs != null)
  {
   fs.Close();
  }
  return null;
  }
 }

以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,同時(shí)也希望多多支持腳本之家!

相關(guān)文章

  • ASP.NET Core中修改配置文件后自動(dòng)加載新配置的方法詳解

    ASP.NET Core中修改配置文件后自動(dòng)加載新配置的方法詳解

    這篇文章主要給大家介紹了關(guān)于ASP.NET Core中修改配置文件后自動(dòng)加載新配置的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用ASP.NET Core具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • 微信公眾平臺(tái)開(kāi)發(fā)之發(fā)送文本消息.Net代碼解析

    微信公眾平臺(tái)開(kāi)發(fā)之發(fā)送文本消息.Net代碼解析

    這篇文章主要為大家詳細(xì)解析了微信公眾平臺(tái)開(kāi)發(fā)之發(fā)送文本消息.Net代碼,感興趣的小伙伴們可以參考一下
    2016-06-06
  • asp.net獲取網(wǎng)站目錄物理路徑示例

    asp.net獲取網(wǎng)站目錄物理路徑示例

    這篇文章主要介紹了asp.net獲取網(wǎng)站目錄物理路徑的方法,需要的朋友可以參考下
    2014-02-02
  • ASP.NET Forms身份認(rèn)證

    ASP.NET Forms身份認(rèn)證

    asp.net程序中,用戶可以根據(jù)角色訪問(wèn)對(duì)應(yīng)頁(yè)面以及功能。本文將對(duì)此進(jìn)行介紹,具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧
    2017-02-02
  • ASP.NET中ServerPush用法實(shí)例分析

    ASP.NET中ServerPush用法實(shí)例分析

    這篇文章主要介紹了ASP.NET中ServerPush用法,實(shí)例分析了通過(guò)ServerPush實(shí)現(xiàn)服務(wù)器推送功能,需要的朋友可以參考下
    2015-06-06
  • ASP.NET Web Page應(yīng)用深入探討

    ASP.NET Web Page應(yīng)用深入探討

    這些內(nèi)容是我在學(xué)習(xí)ASP.Net的時(shí)候?qū)age研究的一些心得,具體的細(xì)節(jié)沒(méi)有很詳細(xì)的探討,更多的內(nèi)容請(qǐng)大家參考MSDN,但是我舉了一些初學(xué)者常犯的錯(cuò)誤和出現(xiàn)錯(cuò)誤的原因,希望可以給大家?guī)?lái)啟發(fā)。
    2009-08-08
  • DropDownList綁定選擇數(shù)據(jù)報(bào)錯(cuò)提示異常解決方案

    DropDownList綁定選擇數(shù)據(jù)報(bào)錯(cuò)提示異常解決方案

    DropDownList控件在綁定選擇數(shù)據(jù)時(shí)提示報(bào)錯(cuò)異常詳細(xì)信息為:有一個(gè)無(wú)效 SelectedValue,因?yàn)樗辉陧?xiàng)目列表中,應(yīng)該有很多新手朋友們遇到過(guò)吧,本文將給予解決方法,感興趣的朋友可以了解下,希望本對(duì)你有所幫助
    2013-01-01
  • .net core使用FastHttpApi構(gòu)建web聊天室實(shí)例代碼

    .net core使用FastHttpApi構(gòu)建web聊天室實(shí)例代碼

    這篇文章主要給大家介紹了關(guān)于.net core使用FastHttpApi構(gòu)建web聊天室的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2018-10-10
  • .NET示波器控件的實(shí)例代碼分析

    .NET示波器控件的實(shí)例代碼分析

    本篇文章是對(duì).NET示波器控件進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • ASP.NET Session對(duì)象保持會(huì)話使用說(shuō)明

    ASP.NET Session對(duì)象保持會(huì)話使用說(shuō)明

    ASP.NET提供了Session對(duì)象,從而允許程序員識(shí)別、存儲(chǔ)和處理同一個(gè)瀏覽器對(duì)象對(duì)服務(wù)器上某個(gè)特定網(wǎng)絡(luò)應(yīng)用程序的若干次請(qǐng)求的上下文信息
    2012-12-12

最新評(píng)論