mvc手把手教你寫excel導入

来源:http://www.cnblogs.com/wangwangwangMax/archive/2017/11/29/7922119.html
-Advertisement-
Play Games

實習狗的每天新知識日常 準備工作: 1.在項目中添加對NPOI的引用,NPOI下載地址:http://npoi.codeplex.com/releases/view/38113 2.NPOI學習系列教程推薦:http://www.cnblogs.com/tonyqus/archive/2009/04 ...


實習狗的每天新知識日常

準備工作:

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

2.NPOI學習系列教程推薦:http://www.cnblogs.com/tonyqus/archive/2009/04/12/1434209.html

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>
excel

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);
                }
        }
            
        }

}
footController.cs

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
    }
}
excelDAL
 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

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


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 首先請確認已購買了阿裡雲主機產品或萬網雲虛擬伺服器,購買產品後才能正常通過阿裡雲提交備案申請,另不同的產品類型,驗證方式也不同: 一、ECS、SLB、ACE和彈性web托管、建站市場(雲市場),產品類型請選擇“阿裡雲”。備案服務號請登錄用戶中心-備案管理中查詢;如何申請備案服務號? 二、雲虛擬主機產 ...
  • 返回總目錄 本小節目錄 Rename Method(函數改名) Add Parameter(添加參數) Remove Parameter(移除參數) 1Rename Method(函數改名) 概要 函數的名稱未能揭示函數的用途。 修改函數的名稱。 動機 將複雜的處理過程分解成小函數是良好的編程風格。 ...
  • 失敗的嘗試: regsvr32註冊:模塊已載入,但找不到入口點DllRegisterServer regasm註冊:需寫上regasm的完整路徑,註冊成功,但問題依舊 將項目的平臺改為x86:問題依舊 問題解決: 把Petro-SIM卸載重裝之後就好了。 之前的安裝,Petro-SIM可以正常使用, ...
  • ASP.NET Identity除了提供基於Cookie的身份驗證外,還提供了一些高級功能,如多次輸入錯誤賬戶信息後會鎖定用戶禁止登錄、集成第三方驗證、賬戶的二次驗證等,並且ASP.NET MVC的預設模板中就帶有這些功能。 本文將從以下幾個方面解釋ASP.NET Identity是如何實現身份驗證 ...
  • 在基於傳統的.NET Framework的Asp.Net Mvc的時候,本地開發環境中可以在IIS中建立一個站點,可以直接把站點的目錄指向asp.net mvc的項目的根目錄。然後build一下就可以在瀏覽器裡面刷新到最新的修改了,也可以附加到w3wp的進程進行調試。但是在開發基於.Net Core ...
  • Redis請求協議的一般形式: 備註:CR表示為\r; LF表示\n 下麵是一個例子: Redis回覆 Redis 命令會返回多種不同類型的回覆。 通過檢查伺服器發回數據的第一個位元組, 可以確定這個回覆是什麼類型: 狀態回覆(status reply)的第一個位元組是 "+" 錯誤回覆(error r ...
  • 生命周期函數:需要繼承 MonoBehaviour 類才能使用。生命周期函數全部都是由系統定義好的,系統會自動調用,且調用順序和我們在代碼裡面的書寫順序無關。 常用的生命周期函數: Awake():喚醒事件,游戲一開始運行就執行,只執行一次。 OnEnable():啟用事件,只執行一次。當腳本組件被 ...
  • hangfire是執行後臺任務的利器,具體請看官網介紹:https://www.hangfire.io/ 新建一個asp.net core mvc 項目 引入nuget包 Hangfire.AspNetCore hangfire的任務需要資料庫持久化,我們在Startup類中修改ConfigureS ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...