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

首頁 > 學院 > 開發設計 > 正文

C# 導出word文檔及批量導出word文檔(4)

2019-11-17 02:11:04
字體:
來源:轉載
供稿:網友

C# 導出Word文檔及批量導出word文檔(4)

接下來是批量導出word文檔和批量打印word文件,批量導出word文檔和批量打印word文件的思路差不多,只是批量打印不用打包壓縮文件,而是把所有文件合成一個word,然后通過js來調用word,提交打印機,把word文檔的內容都打印出來。批量導出word文檔需要用到ICSharpCode.SharpZipLib.dll 插件,思路是,先單獨導出所勾選的數據的單個文檔,保存到生成的臨時目錄下,再把同一個的人相關文檔合并一個word文檔,并刪除已經合并的那個文檔(不是合并后生成的文檔),以姓名和編號命名生成后的文檔,最后將臨時目錄下的所有文件打包壓縮下載,并刪除臨時目錄和臨時目錄下的所有文件(都是生成在服務器上,所以若文件太大,可能會慢)。批量導出是用form來提交所傳的參數,并下載。(因為懶,不解釋代碼了) 首先新建一個空文檔,插入書簽,書簽名為“p”(隨便定義的),命名文件名為“test.doc”,保存在項目目錄下。 相關js代碼為:
  1  /***************************************  2  * @methodname→批量導出word文檔  3  * @createtime 2015-05-11  4  ***************************************/  5 function AllExportWord(objid, tfile) {  6     var ckvalue = "", ntid = "", code = "", name = "";  7     var chkbox = $("input[type=checkbox][name=chk]:checked");  8     for (var i = 0; i < chkbox.length; i++) {  9         ckvalue = ckvalue + chkbox[i].value + ",";  //主鍵值 10         ntid = ntid + $(chkbox[i]).attr("data-ntid") + ","; //學生主鍵 11         code = code + $(chkbox[i]).attr("data-code") + ","; //胸卡號 12         name = name + $(chkbox[i]).attr("data-name") + ","; //姓名 13     } 14     if (ckvalue != "") { 15         ntid = ntid.substring(0, ntid.length - 1); 16         code = code.substring(0, code.length - 1); 17         name = name.substring(0, name.length - 1); 18         $.Ajax({ 19             type: "POST", 20             url: "/NewStudent/BatchExportWord", 21             dataType: "json", 22             data: { tempFile: tfile, ntid: ntid }, 23             async: false, 24             success: function (data) { 25                 if (data.isOK) { 26                     var count = ntid.split(',').length; 27                     if (count == data.ls.length && count > 0) { 28                         DownLoadWord(objid, tfile, ntid, code, name, true); 29                     } 30                     else { 31                         if (confirm("選擇導出的數據中包含沒有學習記錄的數據,是否確認導出或打印?")) { 32                             DownLoadWord(objid, tfile, ntid, code, name, true); 33                         } 34                     } 35                 } 36                 else { 37                     alert(data.msg); 38                 } 39             } 40         }); 41     } 42     else { 43         alert("請選擇數據!"); 44     } 45 } 46 /*************************************** 47  * @methodname→批量導出word文檔 48  * @createtime 2015-05-11 49  ***************************************/ 50 function BatchExportWord(objid, tfile) {    51     var ckvalue = "", ntid = "", code = "", name = ""; 52     var chkbox = $("input[type=checkbox][name=chk]:checked"); 53     for (var i = 0; i < chkbox.length; i++) { 54         ckvalue = ckvalue + chkbox[i].value + ",";  //主鍵值 55         ntid = $(chkbox[i]).attr("data-ntid"); //學生主鍵 56         code = $(chkbox[i]).attr("data-code"); //胸卡號 57         name = $(chkbox[i]).attr("data-name"); //姓名 58     } 59     if (ckvalue != "") { 60         ckvalue = ckvalue.substring(0, ckvalue.length - 1); //去掉最后一個逗號 61         $.ajax({ 62             type: "POST", 63             url: "/NewStudent/BatchExportWord", 64             dataType: "json", 65             data: { tempFile: tfile }, 66             async: false, 67             success: function (data) { 68                 if (data.isOK) { 69                     DownLoadWord(objid, tfile, ntid, code, name, false) 70                 } 71                 else { 72                     alert(data.msg); 73                 } 74  75             } 76         }); 77     } 78     else { 79         alert("請選擇數據!"); 80     } 81 } 82 /************************************************* 83  * @methodname→只能通過流的方式批量導出word文檔 84    在頁尾添加form,通過提交form表單才能下載 85  * @createtime 2015-05-12 86  *************************************************/ 87 function DownLoadWord(idName, tfile, ntid, code, name, isAll) {    88     $("body").find("form.#form1").remove(); 89     var form = "<form id='form1'></form>"; 90     var input = "<input />"; 91     var input1 = "", input2 = "", input3 = "", input4 = "", input5 = "", input6 = ""; 92     input1 = $(input); input1.attr("type", "hidden"); input1.attr("name", "tempFile"); input1.attr("value", tfile); 93     input2 = $(input); input2.attr("type", "hidden"); input2.attr("name", "ntid"); input2.attr("value", ntid); 94     input3 = $(input); input3.attr("type", "hidden"); input3.attr("name", "code"); input3.attr("value", code); 95     input4 = $(input); input4.attr("type", "hidden"); input4.attr("name", "name"); input4.attr("value", name); 96     input5 = $(input); input5.attr("type", "hidden"); input5.attr("name", "isAll"); input5.attr("value", isAll); 97     input6 = $(input); input6.attr("type", "hidden"); input6.attr("name", "idName"); input6.attr("value", idName); 98     $("body").append(form); //將表單放置在web中 99     //添加表單屬性100     $("#form1").attr("style", "display:none");101     $("#form1").attr("target", "");102     $("#form1").attr("method", "post");   103     $("#form1").attr("action", "/NewStudent/DownLoadWord");  104   105     //添加input到表單里106     $("#form1").append(input1)107     $("#form1").append(input1);108     $("#form1").append(input2);109     $("#form1").append(input3);110     $("#form1").append(input4);111     $("#form1").append(input5);112     $("#form1").append(input6);113     $("#form1").submit();114 }
js

相關后臺代碼如下:

  1 #region 壓縮文件及文件夾  2     /// <summary>  3     /// 壓縮文件及文件夾  4     /// </summary>  5     public class ComPRessFileZip  6     {  7         private ZipOutputStream zos = null;  8         private string strBaseDir = "";  9  10         #region 臨時文件夾名稱 11         /// <summary> 12         /// 臨時文件夾名稱 13         /// </summary> 14         /// <param name="name">學生名稱</param> 15         /// <param name="value">學生卡號</param> 16         /// <returns></returns> 17         public string FolderName(string name, string value) 18         { 19             string tempName = ""; 20             if (!string.IsNullOrEmpty(name)) 21             { 22                 tempName = name; 23                 if (!string.IsNullOrEmpty(value)) 24                     tempName += "_" + value; 25                 tempName += "_" + DateTime.Now.ToString("yyyyMMddHHmm"); 26             } 27             else 28             { 29                 tempName = DateTime.Now.ToString("yyyyMMddHHmmss"); //臨時文件夾名稱 30             } 31             return tempName; 32         } 33         #endregion 34  35         #region 創建臨時文件夾 36         /// <summary> 37         /// 創建臨時文件夾 38         /// </summary> 39         /// <param name="name">學生名稱</param> 40         /// <param name="value">學生卡號</param> 41         /// <returns></returns> 42         public string CreateTempFolder(string name, string value = null) 43         { 44             //遍歷服務器指定文件夾下的所有文件 45             string path = "UploadFile"; 46             string serverPath = WordFilePath.GetFilePath(path); 47             string tempName = ""; 48             if (!string.IsNullOrEmpty(value)) 49                 tempName = FolderName(name, value); 50             else 51                 tempName = name; 52             string tempFolder = Path.Combine(serverPath, tempName); 53             Directory.CreateDirectory(tempFolder); //創建臨時文件夾 54
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 国产久草视频在线 | 色悠悠久久久久 | 午夜色视频在线观看 | 韩国精品一区二区三区四区五区 | 精品久久久一二三区播放播放播放视频 | 成年免费在线视频 | 午夜a狂野欧美一区二区 | 国产亚洲福利 | 精品午夜久久 | 久久久久免费精品国产小说色大师 | 91小视频在线观看免费版高清 | 一级做a爰性色毛片免费1 | 国产在线欧美日韩 | 中文字幕爱爱视频 | 日韩黄在线观看 | 国产精品久久久久久久成人午夜 | 亚洲精品日韩色噜噜久久五月 | 国产精品91久久久 | 日韩一级电影在线观看 | 最近免费观看高清韩国日本大全 | 国产精品色综合 | 黄色高清视频网站 | 亚洲欧美国产精品va在线观看 | 欧美一级特黄aaaaaa在线看首页 | 欧美一级免费在线观看 | 激情小视频在线观看 | 成人在线视频播放 | 一级毛片在线视频 | 日韩激情| 麻豆蜜桃在线观看 | 免费在线观看午夜视频 | 亚洲午夜影院在线观看 | 天天干天天碰 | av色偷偷| 午夜免费网 | 久久免费视频在线 | 国产精品视频一区二区三区综合 | 亚洲免费高清 | 综合网天天色 | 国产一级免费不卡 | 国产精品视频一区二区三区四区五区 |