亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > .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网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲tv在线观看| 国产亚洲在线播放| 中文字幕在线视频日韩| 国产不卡在线观看| 国产一区在线播放| 久久69精品久久久久久国产越南| 国产成人欧美在线观看| 正在播放国产一区| 日韩一区av在线| 亚洲天堂网站在线观看视频| 国产色婷婷国产综合在线理论片a| 中日韩美女免费视频网站在线观看| 国产午夜精品视频免费不卡69堂| 亚洲www在线| 91精品国产高清自在线| 欧美日韩中文字幕| 国产午夜精品视频免费不卡69堂| 中文字幕v亚洲ⅴv天堂| 中文字幕久久久| 欧美一二三视频| 亚洲第一页自拍| 精品视频一区在线视频| 亚洲国产婷婷香蕉久久久久久| 日本精品久久久| 国产精品在线看| 麻豆一区二区在线观看| 96精品视频在线| 精品动漫一区二区三区| 日韩美女视频中文字幕| 欧美亚洲激情在线| 欧美在线播放视频| 成人免费福利在线| 日本19禁啪啪免费观看www| 国产精品一区二区三区久久| 国产视频精品xxxx| 精品福利免费观看| 这里只有精品久久| 国产精品成人aaaaa网站| 亚洲欧美国产精品专区久久| 在线观看精品国产视频| 色综合91久久精品中文字幕| 亚洲国产成人91精品| 久久亚洲一区二区三区四区五区高| 色阁综合伊人av| 国产成人avxxxxx在线看| 97色在线观看| 日本精品免费一区二区三区| 992tv成人免费视频| 在线观看不卡av| 91性高湖久久久久久久久_久久99| 成人午夜激情网| 久久久国产一区二区三区| 亚洲欧洲一区二区三区久久| 免费97视频在线精品国自产拍| 国产精品久久精品| 国产精品极品在线| 亚洲成人免费在线视频| 成人国内精品久久久久一区| 精品网站999www| 日本伊人精品一区二区三区介绍| 亚洲美女视频网| 日韩专区在线播放| 91免费看国产| 欧美自拍大量在线观看| 国产成人涩涩涩视频在线观看| 日韩中文字幕在线观看| 91嫩草在线视频| 国产精品老女人视频| 久久久国产视频91| 欧美日韩国内自拍| 国产伦精品一区二区三区精品视频| 日韩视频在线免费| 亚洲欧美日韩久久久久久| 少妇精69xxtheporn| 日韩麻豆第一页| 国产91对白在线播放| 亚洲欧美激情一区| 国产精品尤物福利片在线观看| 亚洲自拍另类欧美丝袜| 日韩精品免费在线观看| 欧美成人精品在线| 国产精品中文字幕在线| 69av在线播放| 亚洲免费影视第一页| 亚洲精品国产综合久久| 中文字幕日韩精品在线| 中文字幕一区二区三区电影| 九九精品在线观看| 久久精品久久久久久国产 免费| 国内精品一区二区三区| 国产美女91呻吟求| 成人激情免费在线| 国产一区二区在线免费视频| 亚洲毛片在线免费观看| 秋霞成人午夜鲁丝一区二区三区| 国产精品亚洲欧美导航| 日本三级韩国三级久久| 亚洲精品第一国产综合精品| 亚洲全黄一级网站| 一区二区三区久久精品| 韩国三级日本三级少妇99| 国产成人黄色av| 国色天香2019中文字幕在线观看| 欧美国产乱视频| 国产成人激情视频| 最近的2019中文字幕免费一页| 国产成人自拍视频在线观看| 国产精品一区二区av影院萌芽| 午夜精品一区二区三区在线视| 日韩av一区在线观看| 欧美一级片久久久久久久| 日韩va亚洲va欧洲va国产| 亚洲精品久久在线| 久久国产精品电影| 91在线视频成人| 国产美女扒开尿口久久久| 91亚洲精品在线观看| 亚洲精品美女在线| 国产不卡视频在线| 欧美xxxx综合视频| 久久久99久久精品女同性| 97精品欧美一区二区三区| 国产福利成人在线| 久久久久久久色| 亚洲国产成人av在线| 高跟丝袜欧美一区| 蜜月aⅴ免费一区二区三区| 成人国产精品一区二区| 国产精品入口尤物| 欧美成人黑人xx视频免费观看| 91国内揄拍国内精品对白| 日本韩国欧美精品大片卡二| 亚洲人成欧美中文字幕| 国产视频福利一区| 日韩在线观看高清| 国产成人精品日本亚洲专区61| 亚洲精品视频中文字幕| 国产成人91久久精品| 亚洲精品欧美一区二区三区| 韩曰欧美视频免费观看| 日韩亚洲欧美中文高清在线| 色哟哟网站入口亚洲精品| 亚洲**2019国产| 亚洲国产精品小视频| 亚洲精品一二区| 中文字幕成人精品久久不卡| 亚洲a级在线播放观看| 亚洲自拍中文字幕| 日韩在线视频中文字幕| 国产综合在线视频| 欧美性理论片在线观看片免费| 欧美成人小视频| 亚洲天堂第二页| 色老头一区二区三区| 色综合五月天导航| 69av视频在线播放| 日韩中文字幕国产精品| 久久久免费av| 国产欧美va欧美va香蕉在线| 国产精品99蜜臀久久不卡二区| 最近2019年日本中文免费字幕| 久久久人成影片一区二区三区| 欧美孕妇毛茸茸xxxx| 欧美xxxx18国产|