程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> C# >> C#入門知識 >> C# 導出word文檔及批量導出word文檔(3),

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

編輯:C#入門知識

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


     在初始化WordHelper時,要獲取模板的相對路徑。獲取文檔的相對路徑多個地方要用到,比如批量導出時要先保存文件到指定路徑下,再壓縮打包下載,所以專門寫了個關於獲取文檔的相對路徑的類。 

1 #region 獲取文檔的相對路徑 2 public class WordFilePath 3 { 4 #region 返回文件帶路徑值 5 /// <summary> 6 /// 返回文件帶路徑值 7 /// </summary> 8 /// <param name="FilePth">文件所在文件夾名稱</param> 9 /// <param name="FileName">文件名</param> 10 /// <returns></returns> 11 public static string FileWithFilePath(string FilePth, string FileName = null) 12 { 13 string strFile = ""; 14 if (!string.IsNullOrEmpty(FilePth)) 15 strFile += "~/" + FilePth + "/"; 16 if (!string.IsNullOrEmpty(FileName)) 17 strFile += FileName; 18 19 return strFile; 20 } 21 #endregion 22 23 #region 判斷文件或文件夾是否存在 24 /// <summary> 25 /// 判斷文件或文件夾是否存在 26 /// </summary> 27 /// <param name="FilePth">文件所在文件夾名稱</param> 28 /// <param name="FileName">文件名</param> 29 /// <returns></returns> 30 public static bool ExistFile(string FilePth, string FileName = null) 31 { 32 return System.IO.File.Exists(GetFilePath(FilePth, FileName)); 33 } 34 #endregion 35 36 #region 獲取文件及文件夾的相對路徑 37 /// <summary> 38 /// 獲取文件及文件夾的相對路徑 39 /// </summary> 40 /// <param name="FilePth"></param> 41 /// <param name="FileName"></param> 42 /// <returns></returns> 43 public static string GetFilePath(string FilePth, string FileName = null) 44 { 45 string strPath = ""; 46 strPath = FileWithFilePath(FilePth, FileName); 47 strPath = HttpContext.Current.Request.MapPath(strPath); 48 return strPath; 49 } 50 #endregion 51 } 52 #endregion View Code

     以上方法可以實現了單個word文檔帶圖片的導出功能了,多個文檔的生成也可以實現,只是還沒有打包下載的代碼。
     最後調用的方法如下,要先判斷模板是否存在:    

1 string strpath = "Content/templates"; //模板所在的文件文件夾 2 string templateFile = "實習生學習記錄表導出模板.doc"; 3 if (WordFilePath.ExistFile(strpath, templateFile)) 4 { 5 string saveName = WordHelper.SaveDocName(form["NTName"], form["CardNo"]); //保存的名稱 6 saveName = HttpUtility.UrlEncode(saveName, Encoding.GetEncoding("utf-8")); 7 WordHelper wordhelper = new WordHelper(templateFile); 8 getWordInfo(wordhelper, templateFile, NTID, stype.ToString(), majorid.ToString(), sequence.ToString()); 9 return base.File(wordhelper.ExportDoc().ToArray(), "application/msword", saveName); 10 } 11 else 12 { 13 return ShowRedirectMessage("導出的模板不存在!", strUrl); 14 } View Code

    getWordInfo方法是為將所需的信息拼湊成一個word文檔,減少代碼的重復性而提取出來的,如:

1 #region 將所有信息拼湊成一個word文檔 2 public void getWordInfo(WordHelper wordhelper, string tempFile, string ntid, string stype, string mid, string sequence) 3 { 4 if (tempFile.Contains("實習生學習記錄表導出模板")) 5 { 6 Dictionary<string, string> dicWhere = new Dictionary<string, string>(); 7 dicWhere.Add("NTID", ntid); 8 wordhelper.GetBasicInfo(typeof(BLL.NewTraineeInfo), dicWhere); 9 PrejobTrainWord(wordhelper, ntid); 10 TrainListWord(wordhelper, ntid, stype, mid); 11 AwardListWord(wordhelper, ntid, stype, mid); 12 ArrangeListWord(wordhelper, ntid, stype); 13 ScoreListWord(wordhelper, ntid, stype, mid, sequence); 14 EvalWord(wordhelper, ntid, stype, mid); 15 } 16 } 17 18 #region 其他信息 19 //崗前培訓 20 public void PrejobTrainWord(WordHelper wordhelper, string ntid) 21 { 22 Dictionary<string, string> dicWhere = new Dictionary<string, string>(); 23 dicWhere.Add("NTID", ntid); 24 wordhelper.GetBasicInfo(typeof(BLL.PrejobTraining), dicWhere); 25 } 26 27 //輪科安排表 28 public void ArrangeListWord(WordHelper wordhelper, string ntid, string stype) 29 { 30 Dictionary<string, string> dicWhere = new Dictionary<string, string>(); 31 dicWhere = new Dictionary<string, string>(); 32 dicWhere.Add("NTID", ntid); 33 dicWhere.Add("StudentType", stype.ToString()); 34 wordhelper.GetTableList(typeof(BLL.MajorCycle), dicWhere, "ArrangeList"); 35 } View Code     ArrangeList是之前在word模板裡所設定的如下圖,用for循環出列表, 圖片

     getWordInfo裡其它的方法類似這兩個。    

     最後導出的word文檔大致如下圖所示:              

圖片

 

圖片

 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved