麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > .NET > 正文

手把手教你mvc導入excel

2024-07-10 13:32:47
字體:
來源:轉載
供稿:網友

準備工作:

1.在項目中添加對NPOI的引用,NPOI下載地址:http://npoi.codeplex.com/releases/view/38113

2.NPOI學習

NPOI下載,里面有五個dll,需要引用到你的項目,我這邊用的mvc4+三層的方式架構的項目

我用的工具是(vs2012+sql2014)

準備工作做完,我們開始進入主題

1.前端頁面,代碼:

<div class="filebtn">         @using (Html.BeginForm("importexcel", "foot", FormMethod.Post, new { enctype = "multipart/form-data" }))          {            <samp>請選擇要上傳的Excel文件:</samp>            <span id="txt_Path"></span>            <strong>選擇文件<input name="file" type="file" id="file" /></strong>@*            @Html.AntiForgeryToken() //防止跨站請求偽造(CSRF:Cross-site request forgery)攻擊           *@<input type="submit" id="ButtonUpload" value="提交"  class="offer"/>           }      </div>

2.接下來就是控制器

 

public class footController : Controller  {    //    // GET: /foot/    private static readonly String Folder = "/files";    public ActionResult excel()    {      return View();    }    /// 導入excel文檔    public ActionResult importexcel()    {      //1.接收客戶端傳過來的數據      HttpPostedFileBase file = Request.Files["file"];      if (file == null || file.ContentLength <= 0)      {        return Json("請選擇要上傳的Excel文件", JsonRequestBehavior.AllowGet);      }      //string filepath = Server.MapPath(Folder);      //if (!Directory.Exists(filepath))      //{      //  Directory.CreateDirectory(filepath);      //}      //var fileName = Path.Combine(filepath, Path.GetFileName(file.FileName));      // file.SaveAs(fileName);      //獲取一個streamfile對象,該對象指向一個上傳文件,準備讀取改文件的內容      Stream streamfile = file.InputStream;      DataTable dt = new DataTable();      string FinName = Path.GetExtension(file.FileName);      if (FinName != ".xls" && FinName != ".xlsx")      {        return Json("只能上傳Excel文檔",JsonRequestBehavior.AllowGet);      }      else      {        try        {          if (FinName == ".xls")          {            //創建一個webbook,對應一個Excel文件(用于xls文件導入類)            HSSFWorkbook hssfworkbook = new HSSFWorkbook(streamfile);            dt = excelDAL.ImExport(dt, hssfworkbook);          }          else          {            XSSFWorkbook hssfworkbook = new XSSFWorkbook(streamfile);            dt = excelDAL.ImExport(dt, hssfworkbook);          }          return Json("",JsonRequestBehavior.AllowGet);        }        catch(Exception ex)        {          return Json("導入失敗 !"+ex.Message, JsonRequestBehavior.AllowGet);        }    }          }}

3.業務邏輯層[excelDAL]

 

using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threading.Tasks;using NPOI;using NPOI.SS.UserModel;using NPOI.HSSF.UserModel;using System.Data;using NPOI.XSSF.UserModel;namespace GJL.Compoent{  public class excelDAL  {    ///<summary>    /// #region 兩種不同版本的操作excel    /// 擴展名*.xlsx    /// </summary>    public static DataTable ImExport(DataTable dt, XSSFWorkbook hssfworkbook)    {      NPOI.SS.UserModel.ISheet sheet = hssfworkbook.GetSheetAt(0);      System.Collections.IEnumerator rows = sheet.GetRowEnumerator();      for (int j = 0; j < (sheet.GetRow(0).LastCellNum); j++)      {        dt.Columns.Add(sheet.GetRow(0).Cells[j].ToString());      }      while (rows.MoveNext())      {        XSSFRow row = (XSSFRow)rows.Current;        DataRow dr = dt.NewRow();        for (int i = 0; i < row.LastCellNum; i++)        {          NPOI.SS.UserModel.ICell cell = row.GetCell(i);          if (cell == null)          {            dr[i] = null;          }          else          {            dr[i] = cell.ToString();          }        }        dt.Rows.Add(dr);      }      dt.Rows.RemoveAt(0);      if (dt!=null && dt.Rows.Count != 0)      {        for (int i = 0; i < dt.Rows.Count; i++)        {          string categary = dt.Rows[i]["頁面"].ToString();          string fcategary = dt.Rows[i]["分類"].ToString();          string fTitle = dt.Rows[i]["標題"].ToString();          string fUrl = dt.Rows[i]["鏈接"].ToString();          FooterDAL.Addfoot(categary, fcategary, fTitle, fUrl);        }      }      return dt;    }    #region 兩種不同版本的操作excel    ///<summary>    /// 擴展名*.xls    /// </summary>    public static DataTable ImExport(DataTable dt, HSSFWorkbook hssfworkbook)    {      // 在webbook中添加一個sheet,對應Excel文件中的sheet,取出第一個工作表,索引是0       NPOI.SS.UserModel.ISheet sheet = hssfworkbook.GetSheetAt(0);      System.Collections.IEnumerator rows = sheet.GetRowEnumerator();      for (int j = 0; j < (sheet.GetRow(0).LastCellNum); j++)      {        dt.Columns.Add(sheet.GetRow(0).Cells[j].ToString());      }      while (rows.MoveNext())      {        HSSFRow row = (HSSFRow)rows.Current;        DataRow dr = dt.NewRow();        for (int i = 0; i < row.LastCellNum; i++)        {          NPOI.SS.UserModel.ICell cell = row.GetCell(i);          if (cell == null)          {            dr[i] = null;          }          else           {            dr[i] = cell.ToString();          }        }        dt.Rows.Add(dr);      }      dt.Rows.RemoveAt(0);      if (dt != null && dt.Rows.Count != 0)      {        for (int i = 0; i < dt.Rows.Count; i++)        {          string categary = dt.Rows[i]["頁面"].ToString();          string fcategary = dt.Rows[i]["分類"].ToString();          string fTitle = dt.Rows[i]["標題"].ToString();          string fUrl = dt.Rows[i]["鏈接"].ToString();          FooterDAL.Addfoot(categary, fcategary, fTitle, fUrl);        }      }      return dt;    }    #endregion  }}
 public static partial class FooterDAL  {    /// <summary>    /// 添加    /// </summary>    /// <param name="id"></param>    /// <param name="catgary"></param>    /// <param name="fcatgary"></param>    /// <param name="fTitle"></param>    /// <param name="fUrl"></param>    /// <returns></returns>    public static int Addfoot(string categary, string fcategary, string fTitle, string fUrl)    {      string sql = string.Format("insert into Foot (categary,fcategary,fTitle,fUrl)values(@categary,@fcategary,@fTitle,@fUrl)");      SqlParameter[] parm =         {            new SqlParameter("@categary",categary)          ,new SqlParameter("@fcategary",fcategary)          ,new SqlParameter("@fTitle",fTitle)          ,new SqlParameter("@fUrl",fUrl)        };      return new DBHelperSQL<Foot>(CommonTool.dbname).ExcuteSql(sql,parm);      }}

//FooterDAL將datatable,就是excel里面的數據添加到sql數據庫

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到ASP.NET教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 午夜精品小视频 | 黄色伊人网站 | av成人免费| 九九黄色 | 久久99国产综合精品 | 黄色大片在线观看 | 成人免费看视频 | 一级α片免费看刺激高潮视频 | 久久综合网址 | 精品在线视频播放 | 91精品国产91久久久久久蜜臀 | 日本羞羞的午夜电视剧 | 五月天影院,久久综合, | 午夜生活理论片 | 久久精品23 | xxxeexxx性国产 | 看国产毛片 | 国产乱淫av| 九九视频久久 | 中国av免费观看 | 亚洲国产馆 | 中国fx性欧美xxxx | 久久99精品国产99久久6男男 | 免费久久精品 | 成人精品| hdhdhd79xxxxх | asiass极品裸体女pics | 国产成年人网站 | 亚洲国产精品500在线观看 | 黄色电影免费提供 | 99成人在线| 日本黄色免费播放 | 免费毛片播放 | 黄网站在线免费看 | 成人羞羞国产免费游戏 | 日韩视频在线不卡 | 亚洲小视频在线 | 国产精品一区二区视频 | 美女亚洲| 操碰97 | 欧美一级特黄aaaaaaa什 |