用MVC導入導出

来源:http://www.cnblogs.com/lyq666666/archive/2017/11/23/7885449.html
-Advertisement-
Play Games

導入導出對於剛做的人一臉懵逼,但是明白思路之後就感覺非常容易,我也是研究了好久,才總算做了出來,放在這裡給大家分享一下 一.先看下導出 視圖腳本 視圖html代碼 控制器代碼 二,從Excel導入資料庫 視圖代碼 控制器代碼 public ActionResult Show(HttpPostedFi ...


導入導出對於剛做的人一臉懵逼,但是明白思路之後就感覺非常容易,我也是研究了好久,才總算做了出來,放在這裡給大家分享一下

一.先看下導出

視圖腳本

<script type ="text/javascript" language="javascript">

        function selectExcel() {

            var GUID = document.getElementsByName("check");

        var temp = "";

        var strGUID = "";

        for (var i = 0; i < GUID.length; i++) {

        if (GUID[i].checked) {

        temp += GUID[i].value + ",";

        }

        }

        

        strGUID =  temp

        //alert(strGUID);//測試取到的值是否正確
        alert(strGUID);
        //$("#GUID").val(strGUID);//將多選的值賦給Id為strGUID的隱藏域
        document.getElementById("strGUID").value = strGUID;
        }

        </script>

 視圖html代碼

@using (Html.BeginForm("DataIn", "Home", FormMethod.Post))
    {
        <table>
            <tr>
                <td>@Html.Hidden("strGUID")</td>
                <td><input type="submit" value="導出" onclick="selectExcel()" /></td>
            </tr>
        </table>
    }

控制器代碼

public ActionResult DataTableToExcel(string strGUID)
        {

            string[] GUID = Request.Form["strGUID"].Split(',');



            //這個是讀取要導出的列表,邏輯要自己寫的
            DataTable dt = new DataTable();
            dt.Columns.Add("序號");
            dt.Columns.Add("姓名");
            foreach (var aa in GUID)
            {
                if(aa!=null&& aa!="")
                {
                    int id=Convert.ToInt32(aa);
                    //List<User> list = db.user.Where(p => p.Uid == id).ToList();
                    User model = db.user.Find(id);
                    dt.Rows.Add(model.Uid,model.Uname);
                }
            }

             //= SQLServerDAL.DSalesOrders.SalesOrders_GetListExcel(strGUID).Tables[0];



            System.Web.UI.WebControls.DataGrid dgExport = null;

            // 當前對話 

            System.Web.HttpContext curContext = System.Web.HttpContext.Current;

            // IO用於導出並返回excel文件 

            System.IO.StringWriter strWriter = null;

            System.Web.UI.HtmlTextWriter htmlWriter = null;

            string filename = DateTime.Now.Year + "_" + DateTime.Now.Month + "_" + DateTime.Now.Day + "_"

            + DateTime.Now.Hour + "_" + DateTime.Now.Minute;

            byte[] str = null;



            if (dt != null)
            {

                // 設置編碼和附件格式

                curContext.Response.Charset = "GB2312";

                Response.AppendHeader("Content-Disposition", "attachment;filename=" + filename + ".xls");

                curContext.Response.ContentEncoding = System.Text.Encoding.GetEncoding("GB2312");//設置輸出流為簡體中文

                curContext.Response.ContentType = "application/vnd.ms-excel";

                //System.Text.Encoding.UTF8;

                // 導出excel文件 

                strWriter = new System.IO.StringWriter();

                htmlWriter = new System.Web.UI.HtmlTextWriter(strWriter);



                //// 為瞭解決dgData中可能進行了分頁的情況,需要重新定義一個無分頁的DataGrid 

                dgExport = new System.Web.UI.WebControls.DataGrid();

                dgExport.DataSource = dt.DefaultView;

                dgExport.AllowPaging = false;

                dgExport.DataBind();

                dgExport.RenderControl(htmlWriter);

                // 返回客戶端 

                str = System.Text.Encoding.UTF8.GetBytes(strWriter.ToString());

            }

            return File(str, "attachment;filename=" + filename + ".xls");

        }

<!--如果報格式亂碼錯誤  把設置編碼和附件格式下的代碼換成下麵代碼-->

curContext.Response.Charset = "GB2312";

                Response.AppendHeader("Content-Disposition", "attachment;filename=" + filename + ".xls");

                curContext.Response.ContentEncoding = Encoding.Default;//設置輸出流為簡體中文

                curContext.Response.ContentType = "application/vnd.ms-excel";

                Response.Write("<meta http-equiv=\"content-type\" content=\"application/vnd.ms-excel; charset=utf-8\"/>");//加上這句話string類型就不亂碼了

二,從Excel導入資料庫

視圖代碼

 @using (Html.BeginForm("Show", "Home", FormMethod.Post, new { enctype = "multipart/form-data" }))
       {
        
                <p>
                    選擇文件:<input id="FileUpload" type="file" name="files" style="width: 250px; height: 24px;
                    background: White" class="easyui-validatebox" />
                </p>
                <p>
                    <input id="btnImport" type="submit" value="導入" style="width: 60px; height: 28px;" />
                </p>
       }

控制器代碼

public ActionResult Show(HttpPostedFileBase filebase)
{
HttpPostedFileBase file=Request.Files["files"];
string FileName;
string savePath;
if (file == null||file.ContentLength<=0)
{
ViewBag.error = "文件不能為空";
return View();
}
else
{
string filename= Path.GetFileName(file.FileName);
int filesize = file.ContentLength;//獲取上傳文件的大小單位為位元組byte
string fileEx = System.IO.Path.GetExtension(filename);//獲取上傳文件的擴展名
string NoFileName = System.IO.Path.GetFileNameWithoutExtension(filename);//獲取無擴展名的文件名
int Maxsize = 4000 * 1024;//定義上傳文件的最大空間大小為4M
string FileType = ".xls,.xlsx";//定義上傳文件的類型字元串

FileName = NoFileName + DateTime.Now.ToString("yyyyMMddhhmmss") + fileEx;
if (!FileType.Contains(fileEx))
{
ViewBag.error = "文件類型不對,只能導入xls和xlsx格式的文件";
return View();
}
if (filesize >= Maxsize)
{
ViewBag.error = "上傳文件超過4M,不能上傳";
return View();
}
string path = AppDomain.CurrentDomain.BaseDirectory + "Excel/";
savePath = Path.Combine(path, FileName);
file.SaveAs(savePath);
}

//string result = string.Empty;
string strConn;
strConn = "Provider=Microsoft.Ace.OleDb.12.0;" + "data source=" + savePath + ";Extended Properties='Excel 12.0; HDR=Yes; IMEX=1'";
OleDbConnection conn = new OleDbConnection(strConn);
conn.Open();
OleDbDataAdapter myCommand = new OleDbDataAdapter("select * from [Sheet1$]", strConn);
DataSet myDataSet = new DataSet();
try
{
myCommand.Fill(myDataSet, "ExcelInfo");
}
catch (Exception ex)
{
ViewBag.error = ex.Message;
return View();
}
DataTable table = myDataSet.Tables["ExcelInfo"].DefaultView.ToTable();

//引用事務機制,出錯時,事物回滾
using (TransactionScope transaction = new TransactionScope())
{
for (int i = 0; i < table.Rows.Count; i++)
{
////獲取地區名稱
//string _areaName = table.Rows[i][0].ToString();
////判斷地區是否存在
//if (!_areaRepository.CheckAreaExist(_areaName))
//{
// ViewBag.error = "導入的文件中:" + _areaName + "地區不存在,請先添加該地區";
// return View();
//}
//else
//{
// Station station = new Station();
// station.AreaID = _areaRepository.GetIdByAreaName(_areaName).AreaID;
// station.StationName = table.Rows[i][1].ToString();
// station.TerminaAddress = table.Rows[i][2].ToString();
// station.CapacityGrade = table.Rows[i][3].ToString();
// station.OilEngineCapacity = decimal.Parse(table.Rows[i][4].ToString());
// _stationRepository.AddStation(station);
//}
User model = new User();
model.Uname = table.Rows[i][0].ToString();
db.user.Add(model);
db.SaveChanges();
}
transaction.Complete();
}
ViewBag.error = "導入成功";
System.Threading.Thread.Sleep(2000);
return Content("<script>alert('數據導入成功!');location.href='/Home/Index'</script>");
}

三:註意,

導出中的事務機制需要引用 using System.Transactions;

若是沒有添加這個.dll組件可以去程式集中添加引用

 


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

-Advertisement-
Play Games
更多相關文章
  • 現在說一下程式處理部分,有點長 本來是想做針對doc和docx的模板兩個版本, 後來想到可以在生成的時候saveas里設置格式, 所以此版只支持對docx的模板處理, 想要doc的情況可以選擇生成格式為doc的. 上代碼: public class WordHelper { private Word ...
  • 既然是模板就少不了各種標記和配置. 這裡主要用到了word的書簽功能. 打開word按ctrl+shift+F5, 打開書簽功能 如下圖 如果所示, 可以選中word中的一個區域然後按ctrl+shift+F5, 對此部分添加一個書簽 是否理解為這樣是為這部分區域添加了指針? 根據圖中的操作就可以明 ...
  • 還是以學生、語文、數學、分數為例吧, 感覺這個和helloworld都有一拼了. 造一張表如下, 整張報表就圍繞這個表轉圈了, 順便說下就是名字如有雷同純屬巧合 新建個存儲過程 ALTER PROCEDURE [dbo].[StudentReport] AS BEGIN select 學期,max( ...
  • using System.Linq; List<string> ListA = new List<string>(); List<string> ListB = new List<string>(); List<string> ListResult = new List<string>(); Lis ...
  • 經常遇到這樣的需求, 生成Word格式的報告, 而不是單純的一張表格的報表. 就像體檢報告一樣. 數據來源部分決定採用一個存儲過程返回Dataset的方式, 整張報告的數據來源於此Dataset的多個Datatable. 首先通過配置文件遍歷Dataset生成Word文檔, 但這就意味著要配置的內容 ...
  • HiLo是在NHiernate中生成主鍵的一種方式,不過現在我們可以在Entity Framework Core中使用。所以在這篇內容中,我將向您在如何使用HiL在Entity Framework Core生成主鍵。 ...
  • 1. 前言 這是我最近項目剛要的需求,然後在網上找了半天的教材 但是很不幸,有關於Epplus的介紹真的太少了,然後經過了我的不斷研究然後不斷的採坑,知道現在看到Excel都想吐的時候,終於成功的完成了公司的要求,最後我 稍微的優化了一下代碼(畢竟是個剛工作一年多的新人),現在就給大家看一看不足之處 ...
  • 一,最近在學習abp的東西。發現其中作者在獲取數據時,大量的使用了async和awaiit。好吧,因為不太懂,所以網上搜搜,在這裡記錄一下。 先來看一段代碼。調用UpdateUserAsync會返回一個Task,那task是個啥呢。根據騰飛(Jesse)的說法,task是async和awaiit的叔 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...