国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

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

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
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 仙桃市| 永德县| 文安县| 桑植县| 彭州市| 射洪县| 揭西县| 即墨市| 贵南县| 凭祥市| 清苑县| 南宁市| 乐清市| 福建省| 和田市| 七台河市| 浏阳市| 防城港市| 乌鲁木齐县| 兴文县| 陆河县| 无极县| 青神县| 长岛县| 无棣县| 乌拉特中旗| 本溪市| 阜阳市| 余姚市| 阿荣旗| 兴城市| 乌拉特前旗| 孝感市| 丽江市| 龙胜| 夏邑县| 延津县| 蓝山县| 勐海县| 平山县| 马山县|