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

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

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
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久精品国产91精品亚洲| 中文字幕av一区中文字幕天堂| 亚洲成人激情图| 日本一区二区三区四区视频| 亚洲精品自拍视频| 亚洲精品不卡在线| 国产精品第一第二| 亚洲视频网站在线观看| 成人午夜黄色影院| 性亚洲最疯狂xxxx高清| 国产综合在线观看视频| 日韩中文字幕在线播放| 81精品国产乱码久久久久久| 精品久久久久久中文字幕| 亚洲毛片在线观看| 中文在线不卡视频| 日韩久久精品电影| 久久久精品影院| 日本韩国欧美精品大片卡二| 精品欧美一区二区三区| 午夜精品福利在线观看| 国产精品欧美久久久| 91免费版网站入口| 亚洲桃花岛网站| 国产va免费精品高清在线| 欧美精品少妇videofree| 国语对白做受69| 精品亚洲夜色av98在线观看| 青青草原一区二区| 亚洲成人网在线| 精品久久久香蕉免费精品视频| 国产精品欧美激情在线播放| 亚洲国产精品99久久| 国产精品自拍小视频| 色偷偷噜噜噜亚洲男人的天堂| 欧美大片va欧美在线播放| 97久久精品人搡人人玩| 伊人久久综合97精品| 国产在线播放不卡| 国产美女久久久| 亚洲一区二区三区视频| 国产精品美女呻吟| 午夜剧场成人观在线视频免费观看| 91精品国产99久久久久久| 久久亚洲精品网站| 欧美激情一区二区久久久| 久久久久久久久久国产| 一区二区三区高清国产| 国产精品久久久久77777| 国产剧情日韩欧美| 亚洲精品一区二区网址| 一本一本久久a久久精品牛牛影视| 欧美丰满片xxx777| 亚洲国产精品久久精品怡红院| 91夜夜揉人人捏人人添红杏| 欧美亚洲一区在线| 国产精品一久久香蕉国产线看观看| 久久九九有精品国产23| 久久久久久久久久久久久久久久久久av| 97超碰色婷婷| 国产精品99免视看9| 日韩亚洲欧美中文高清在线| 高清在线视频日韩欧美| 久久视频国产精品免费视频在线| 久久男人av资源网站| 欧美精品一区在线播放| 欧美综合在线第二页| 亚洲精品国精品久久99热| 91九色单男在线观看| 日韩专区在线播放| www.亚洲人.com| 亚洲国产精品久久久久秋霞蜜臀| 欧美xxxx做受欧美.88| 欧美激情一区二区三区在线视频观看| 欧美富婆性猛交| 国产a∨精品一区二区三区不卡| 国产一区欧美二区三区| 91极品女神在线| 日韩欧美中文字幕在线观看| 国产成人精品一区二区在线| 成人黄色av免费在线观看| 日韩电影免费在线观看中文字幕| 中文字幕久精品免费视频| 亚洲精品99999| 福利精品视频在线| 中文在线资源观看视频网站免费不卡| 日本免费在线精品| 国产精品老女人视频| 国产精品欧美激情在线播放| 亚洲人成电影网| 久久人人爽人人| 黑丝美女久久久| 欧美黑人极品猛少妇色xxxxx| 亚洲欧美综合精品久久成人| 日韩精品视频免费专区在线播放| 欧美亚洲另类激情另类| 欧美日韩爱爱视频| 一区二区三区四区视频| 国产区精品在线观看| 日本国产欧美一区二区三区| 亚洲欧美国产日韩天堂区| 日本精品免费观看| 国产精品久在线观看| 成人中文字幕在线观看| 国产精品精品一区二区三区午夜版| 欧美另类69精品久久久久9999| 国产成人avxxxxx在线看| 久久亚洲精品一区| 国产日韩亚洲欧美| 日本a级片电影一区二区| 欧美日产国产成人免费图片| 在线观看国产成人av片| 欧美不卡视频一区发布| 精品二区三区线观看| 亚洲精品视频在线播放| 性欧美视频videos6一9| 欧美激情在线观看| 亚洲free性xxxx护士白浆| 日日摸夜夜添一区| 久久久久久久久久av| 欧美日韩精品在线播放| 欧美丝袜一区二区三区| 午夜精品久久久久久久久久久久久| 久久久91精品国产| 精品亚洲男同gayvideo网站| 中文在线资源观看视频网站免费不卡| 日韩亚洲国产中文字幕| 午夜精品久久久99热福利| 国产精品日韩久久久久| 最近2019中文字幕第三页视频| 日韩欧美一区二区三区| 欧美日韩中文字幕综合视频| 亚洲男人天堂九九视频| 精品亚洲一区二区三区| 38少妇精品导航| 亚洲新中文字幕| 不用播放器成人网| 国产一区二区精品丝袜| 这里只有精品丝袜| 揄拍成人国产精品视频| 日韩欧美国产成人| 成人精品福利视频| 高潮白浆女日韩av免费看| 亚洲偷熟乱区亚洲香蕉av| 久久精品成人欧美大片古装| 欧美xxxx18国产| 久久久久久亚洲精品中文字幕| 国产午夜精品视频免费不卡69堂| 久久精品国产免费观看| 亚洲精品自在久久| 日韩在线视频免费观看| 欧美激情a∨在线视频播放| 日韩av影视综合网| 日韩精品在线视频| 亚洲一区免费网站| 97**国产露脸精品国产| 91亚洲国产精品| 欧美日韩免费在线观看| 亚洲男人的天堂在线播放| 亚洲精品久久久久久久久久久久久| 欧美一级在线亚洲天堂| 欧美大尺度电影在线观看| 美女视频黄免费的亚洲男人天堂| 国产精品丝袜高跟|