c#(.net) 导出 word表格

做了差不多一周的导出Word,现在把代码贴出来   :

ExportWord.cs

  1 using System;
  2 using System.Collections.Generic;
  3 using System.Linq;
  4 using System.Web;
  5 using System.Data;
  6 using System.IO;
  7 
  8 
  9 /// <summary>
 10 ///DaoChuWord 的摘要说明
 11 /// </summary>
 12 public class ExportWord
 13 {
 14     public ExportWord()
 15     {
 16         //
 17         //TODO: 在此处添加构造函数逻辑
 18         //
 19     }
 20 
 21     public DataTable dat = null;
 22     public void ProcessRequest(HttpContext context, string id,string name)
 23     {
 24         context.Response.ContentType = "text/plain";
 25         GetDataTable(id);
 26         CreateWord(name);  
 27         //此处为了批量操作,把下面这个注掉
 28         //context.Response.End();
 29 
 30     }
 31 
 32     DataTable GetDataTable(string id)
 33     {
 34         string sql = " select * from hr_person where id =" + id;
 35         dat = ZWL.DBUtility.MyDBHelp.GetDataTable(sql);
 36         if (dat != null)
 37         {
 38             return dat;
 39         }
 40         throw new NoNullAllowedException();
 41     }
 42 
 43     public string CreateWord(string name)
 44     {
 45         string uid = dat.Rows[0]["id"].ToString();
 46         string message = "";
 47         
 49             Object Nothing = System.Reflection.Missing.Value;
 50            
 52             object filename = name;  //文件保存路径  
 53          54             //创建Word文档 
 55             Microsoft.Office.Interop.Word.Application WordApp = new Microsoft.Office.Interop.Word.ApplicationClass();
 56           
 57             Microsoft.Office.Interop.Word.Document WordDoc = WordApp.Documents.Add(ref Nothing, ref Nothing, ref Nothing, ref Nothing);
 58             WordApp.Selection.PageSetup.LeftMargin = 50f;
 59             WordApp.Selection.PageSetup.RightMargin = 50f;
 60             WordApp.Selection.PageSetup.PageWidth = 650f;  //页面宽度 
 61 
 62             WordDoc.ActiveWindow.Selection.Font.Bold = 2;
 63 
 64             
 70             WordApp.Selection.ParagraphFormat.LineSpacing = 13f;//设置文档的行间距      
 71             //移动焦点并换行 
 72             object count = 14;
 73             object WdLine = Microsoft.Office.Interop.Word.WdUnits.wdLine;//换一行;
 74             WordApp.Selection.ParagraphFormat.LineSpacing = 18f;
 75             
 76             WordApp.Selection.ParagraphFormat.Alignment = Microsoft.Office.Interop.Word.WdParagraphAlignment.wdAlignParagraphCenter;
 77             WordApp.Selection.MoveDown(ref WdLine, ref count, ref Nothing);//移动焦点 
 78             WordApp.Selection.ParagraphFormat.Alignment = Microsoft.Office.Interop.Word.WdParagraphAlignment.wdAlignParagraphCenter;
 79             WordApp.Selection.TypeParagraph();//插入段落 
 80             WordApp.Selection.ParagraphFormat.Alignment = Microsoft.Office.Interop.Word.WdParagraphAlignment.wdAlignParagraphLeft;
 81             WordApp.Selection.Font.Size = 18f;
 82 
 83             object missing = System.Reflection.Missing.Value;
 84             object count2 = 14;
 85             object WdLine2 = Microsoft.Office.Interop.Word.WdUnits.wdLine;//换一行;   
 86             WordApp.Selection.Text = "应 聘 报 名 表";
 87             WordApp.Selection.ParagraphFormat.LineSpacingRule = Microsoft.Office.Interop.Word.WdLineSpacing.wdLineSpaceSingle;//单倍行距
 88 
 89            
 90             WordApp.Selection.ParagraphFormat.Alignment = Microsoft.Office.Interop.Word.WdParagraphAlignment.wdAlignParagraphCenter;
 91             WordApp.Selection.MoveDown(ref WdLine, ref count, ref Nothing);//移动焦点 
 92             WordApp.Selection.ParagraphFormat.Alignment = Microsoft.Office.Interop.Word.WdParagraphAlignment.wdAlignParagraphCenter;
 93             WordApp.Selection.TypeParagraph();//插入段落 
 94             
 95             WordApp.Selection.Font.Size = 10.5f;
 96             WordApp.Selection.ParagraphFormat.Alignment = Microsoft.Office.Interop.Word.WdParagraphAlignment.wdAlignParagraphLeft;
 97             WordApp.Selection.Font.Color = Microsoft.Office.Interop.Word.WdColor.wdColorBlack;
 98 
 99             //文档中创建表格 
100             Microsoft.Office.Interop.Word.Table newTable = WordDoc.Tables.Add(WordApp.Selection.Range, 19, 15, ref Nothing, ref Nothing);
101             //设置表格样式 
102             WordApp.Selection.ParagraphFormat.Alignment = Microsoft.Office.Interop.Word.WdParagraphAlignment.wdAlignParagraphCenter;//水平居中 
103 
104             //设置表格框
105             newTable.Borders.OutsideLineStyle = Microsoft.Office.Interop.Word.WdLineStyle.wdLineStyleSingle;
106             newTable.Columns[1].Width = 25f;
107             newTable.Columns[2].Width = 30f;
108             newTable.Columns[3].Width = 25f;
109             newTable.Columns[4].Width = 45f;
110             newTable.Columns[5].Width = 25f;
111             newTable.Columns[6].Width = 25f;
112             newTable.Columns[7].Width = 35f;
113             newTable.Columns[8].Width = 40f;
114             newTable.Columns[9].Width = 35f;
115             newTable.Columns[10].Width = 15f;
116             newTable.Columns[11].Width = 45f;
117             newTable.Columns[12].Width = 30f;
118             newTable.Columns[13].Width = 40f;
119             newTable.Columns[14].Width = 50f;
120             newTable.Columns[15].Width = 90f;
121 
122             //填充表格内容 
123             for (int k = 1; k < 19; k++)
124             {
125                 newTable.Rows[k].Borders.OutsideLineStyle = Microsoft.Office.Interop.Word.WdLineStyle.wdLineStyleSingle;
126             }
127             for (int k = 1; k < 15; k++)
128             {
129                 newTable.Columns[k].Borders.OutsideLineStyle = Microsoft.Office.Interop.Word.WdLineStyle.wdLineStyleSingle;
130             }
131             //垂直居中
132             object unit = Microsoft.Office.Interop.Word.WdUnits.wdLine;
133             object countjz = 1;
134             WordApp.Selection.MoveEnd(ref unit, ref countjz);
135             WordApp.Selection.Cells.VerticalAlignment = Microsoft.Office.Interop.Word.WdCellVerticalAlignment.wdCellAlignVerticalCenter;//垂直居中 
136 
137             //填充表格内容 第一行
138             newTable.Cell(1, 1).Range.Text = "姓名";
139           //合并单元格 
140             newTable.Cell(1, 1).Merge(newTable.Cell(1, 2));
141             newTable.Cell(1, 2).Range.Text = dat.Rows[0]["name"].ToString();
142 
143             newTable.Cell(1, 2).Merge(newTable.Cell(1, 3));
144             newTable.Cell(1, 3).Range.Text = "性 别";
145             newTable.Cell(1, 3).Merge(newTable.Cell(1, 4));
146             newTable.Cell(1, 4).Range.Text = dat.Rows[0]["sex"].ToString();
147             newTable.Cell(1, 4).Merge(newTable.Cell(1, 5));
148             newTable.Cell(1, 5).Range.Text = "出  生日  期";
149             newTable.Cell(1, 5).Merge(newTable.Cell(1, 6));
150             if (dat.Rows[0]["createdate"].ToString().Equals(""))
151             {
152                 newTable.Cell(1, 6).Range.Text = "";
153             }
154             else
155             {
156                 newTable.Cell(1, 6).Range.Text = DateTime.Parse(dat.Rows[0]["createdate"].ToString()).ToString("yyyy-MM-dd");
157             }
158             newTable.Cell(1, 6).Merge(newTable.Cell(1, 7));
159             newTable.Cell(1, 7).Range.Text = "民 族";
160             newTable.Cell(1, 8).Range.Text = dat.Rows[0]["minzu"].ToString();
161 
162             newTable.Cell(1, 9).Merge(newTable.Cell(3, 15));
163             newTable.Cell(1, 9).Select();//选中一行 
164 
165             string FileName = "E:\\OA\\new\\web2\\upload\\" + dat.Rows[0]["touxiang"].ToString();
166             object LinkToFile = false;
167             object SaveWithDocument = true;
168             object Anchor = WordDoc.Application.Selection.Range;
169             WordDoc.Application.ActiveDocument.InlineShapes.AddPicture(FileName, ref LinkToFile, ref SaveWithDocument, ref Anchor);
170             WordDoc.Application.ActiveDocument.InlineShapes[1].Width = 72f;//图片宽度 
171             WordDoc.Application.ActiveDocument.InlineShapes[1].Height = 90f;//图片高 
172             WordApp.Selection.ParagraphFormat.Alignment = Microsoft.Office.Interop.Word.WdParagraphAlignment.wdAlignParagraphCenter;
173 
174             // 填充表格内容 第二行
175             newTable.Cell(2, 1).Range.Text = "籍  贯";
176             newTable.Cell(2, 1).Merge(newTable.Cell(2, 2));
177             newTable.Cell(2, 2).Range.Text = dat.Rows[0]["jiguan"].ToString();
178             newTable.Cell(2, 2).Merge(newTable.Cell(2, 3));
179             newTable.Cell(2, 3).Range.Text = "出生地";
180             newTable.Cell(2, 3).Merge(newTable.Cell(2, 4));
181             newTable.Cell(2, 4).Range.Text = dat.Rows[0]["chushengdi"].ToString();
182             newTable.Cell(2, 4).Merge(newTable.Cell(2, 5));
183             newTable.Cell(2, 5).Range.Text = "户  口所在地";
184             newTable.Cell(2, 5).Merge(newTable.Cell(2, 6));
185             newTable.Cell(2, 6).Range.Text = dat.Rows[0]["hukouaddress"].ToString();
186             newTable.Cell(2, 6).Merge(newTable.Cell(2, 7));
187             newTable.Cell(2, 7).Range.Text = "身 高";
188             newTable.Cell(2, 8).Range.Text = dat.Rows[0]["shengao"].ToString();
189 
190 
191             //填充表格内容 第三行
192             newTable.Cell(3, 1).Range.Text = "政治面貌";
193             newTable.Cell(3, 1).Merge(newTable.Cell(3, 2));
194             newTable.Cell(3, 2).Range.Text = dat.Rows[0]["zhengzhi"].ToString();
195             newTable.Cell(3, 2).Merge(newTable.Cell(3, 3));
196             newTable.Cell(3, 3).Range.Text = "入   党时   间";
197             newTable.Cell(3, 3).Merge(newTable.Cell(3, 4));
198             if (dat.Rows[0]["rudangdate"].ToString().Equals(""))
199             {
200                 newTable.Cell(3, 4).Range.Text = "";
201             }
202             else
203             {
204                 newTable.Cell(3, 4).Range.Text = DateTime.Parse(dat.Rows[0]["rudangdate"].ToString()).ToString("yyyy-MM-dd");
205             }
206             newTable.Cell(3, 4).Merge(newTable.Cell(3, 5));
207             newTable.Cell(3, 5).Range.Text = "参加工作时间";
208             newTable.Cell(3, 5).Merge(newTable.Cell(3, 6));
209             if (dat.Rows[0]["canjiaworktime"].ToString().Equals(""))
210             {
211                 newTable.Cell(3, 6).Range.Text = "";
212             }
213             else
214             {
215                 newTable.Cell(3, 6).Range.Text = DateTime.Parse(dat.Rows[0]["canjiaworktime"].ToString()).ToString("yyyy-MM-dd");
216             }
217             newTable.Cell(3, 6).Merge(newTable.Cell(3, 7));
218             newTable.Cell(3, 7).Range.Text = "婚姻状况";
219             newTable.Cell(3, 8).Range.Text = dat.Rows[0]["hunyin"].ToString();
220 
221             //填充表格内容 第四行
222             newTable.Cell(4, 1).Range.Text = "移动电话";
223             newTable.Cell(4, 1).Merge(newTable.Cell(4, 2));
224             newTable.Cell(4, 2).Range.Text = dat.Rows[0]["phone"].ToString();
225             newTable.Cell(4, 2).Merge(newTable.Cell(4, 3));
226             newTable.Cell(4, 3).Range.Text = "其他联系方式";
227             newTable.Cell(4, 3).Merge(newTable.Cell(4, 4));
228             newTable.Cell(4, 4).Range.Text = dat.Rows[0]["qitalianxi"].ToString();
229             newTable.Cell(4, 4).Merge(newTable.Cell(4, 5));
230             newTable.Cell(4, 5).Range.Text = "E-mail";
231             newTable.Cell(4, 5).Merge(newTable.Cell(4, 6));
232             newTable.Cell(4, 6).Range.Text = dat.Rows[0]["email"].ToString();
233             newTable.Cell(4, 6).Merge(newTable.Cell(4, 8));
234             newTable.Cell(4, 7).Range.Text = "档  案所在地";
235             newTable.Cell(4, 8).Range.Text = dat.Rows[0]["danganaddress"].ToString();
236 
237             //填充表格内容 第五行
238             newTable.Cell(5, 1).Range.Text = " 身份证 号  码";
239             newTable.Cell(5, 1).Merge(newTable.Cell(5, 2));
240             newTable.Cell(5, 2).Range.Text = dat.Rows[0]["zhengjiannum"].ToString();
241             newTable.Cell(5, 2).Merge(newTable.Cell(5, 7));
242             newTable.Cell(5, 3).Range.Text = "是否曾投递简历到XXXXXX:(如果是,请注明投递时间)";
243             newTable.Cell(5, 3).Merge(newTable.Cell(5, 8));
244             newTable.Cell(5, 4).Range.Text = dat.Rows[0]["ifcengtoudi"].ToString();
245 
246 
247             //填充表格内容 第六行
248             newTable.Cell(6, 1).Range.Text = "家庭住址";
249             newTable.Cell(6, 1).Merge(newTable.Cell(6, 2));
250             newTable.Cell(6, 2).Range.Text = dat.Rows[0]["tongxunaddress"].ToString();
251             newTable.Cell(6, 2).Merge(newTable.Cell(6, 6));
252             newTable.Cell(6, 3).Range.Text = "驾龄";
253             newTable.Cell(6, 4).Range.Text = dat.Rows[0]["jialing"].ToString();
254             newTable.Cell(6, 5).Range.Text = "外语种类及熟练程度";
255             newTable.Cell(6, 5).Merge(newTable.Cell(6, 6));
256             newTable.Cell(6, 6).Range.Text = dat.Rows[0]["waiyu"].ToString();
257             newTable.Cell(6, 6).Merge(newTable.Cell(6, 7));
258             newTable.Cell(6, 7).Range.Text = "微机操作能力";
259             newTable.Cell(6, 8).Range.Text = dat.Rows[0]["weiji"].ToString();
260 
261             //填充表格内容 第七行
262             newTable.Cell(7, 1).Range.Text = "收到录用通知后可到岗时间";
263             newTable.Cell(7, 1).Merge(newTable.Cell(7, 6));
264             if (dat.Rows[0]["daogangdate"].ToString().Equals("三天内"))
265             {
266                 newTable.Cell(7, 2).Range.Text = " □三天内        √一周内      □两周内      □一个月内 ";
267 
268             }
269             if (dat.Rows[0]["daogangdate"].ToString().Equals("一周内"))
270             {
271                 newTable.Cell(7, 2).Range.Text = " □三天内        √一周内      □两周内      □一个月内 ";
272 
273             }
274             if (dat.Rows[0]["daogangdate"].ToString().Equals("两周内"))
275             {
276                 newTable.Cell(7, 2).Range.Text = " □三天内        □一周内      √两周内      □一个月内 ";
277 
278             }
279             if (dat.Rows[0]["daogangdate"].ToString().Equals("一个月内"))
280             {
281                 newTable.Cell(7, 2).Range.Text = " □三天内        □一周内      □两周内      √一个月内 ";
282 
283             }
284             newTable.Cell(7, 2).Merge(newTable.Cell(7, 10));
285             newTable.Cell(7, 1).Select();//选中一行 
286             WordApp.Selection.ParagraphFormat.LineSpacing = 25f;
287             //填充表格内容 第八行
288             newTable.Cell(8, 1).Range.Text = "应聘信息来  源";
289             newTable.Cell(8, 1).Merge(newTable.Cell(8, 2));
290 
291 
292             if (dat.Rows[0]["xinxilaiyuan"].ToString().Equals("华商报无忧招聘"))
293             {
294                 newTable.Cell(8, 2).Range.Text = "√华商报无忧招聘   □中华英才网  □智联招聘   □其他(                    )";
295             }
296             if (dat.Rows[0]["xinxilaiyuan"].ToString().Equals("中华英才网"))
297             {
298                 newTable.Cell(8, 2).Range.Text = "□华商报无忧招聘   √中华英才网  □智联招聘   □其他(                    )";
299             }
300             if (dat.Rows[0]["xinxilaiyuan"].ToString().Equals("智联招聘"))
301             {
302                 newTable.Cell(8, 2).Range.Text = "□华商报无忧招聘   □中华英才网  √智联招聘   □其他(                    )";
303             }
304             if (dat.Rows[0]["xinxilaiyuan"].ToString().Equals("其他"))
305             {
306                 newTable.Cell(8, 2).Range.Text = "□华商报无忧招聘   □中华英才网  □智联招聘   √其他(                    )";
307             }
308             newTable.Cell(8, 2).Merge(newTable.Cell(8, 14));
309 
310             //填充表格内容 第九行
311             newTable.Cell(9, 1).Range.Text = "工作意向";
312             newTable.Cell(9, 1).Merge(newTable.Cell(9, 2));
313 
314 
315             newTable.Cell(9, 1).Merge(newTable.Cell(10, 2));
316 
317             newTable.Cell(9, 2).Range.Text = "期望的工作岗位及职务:" + dat.Rows[0]["qiwangwork"].ToString();
318             newTable.Cell(9, 2).Merge(newTable.Cell(9, 14));
319             newTable.Cell(9, 2).Select();//选中一行 
320             WordApp.Selection.ParagraphFormat.LineSpacing = 25f;
321             //填充表格内容 第十行
322 
323             newTable.Cell(10, 2).Range.Text = "期望薪资待遇:" + dat.Rows[0]["qiwangmoney"].ToString();
324             newTable.Cell(10, 2).Merge(newTable.Cell(10, 14));
325             newTable.Cell(10, 2).Select();//选中一行 
326             WordApp.Selection.ParagraphFormat.LineSpacing = 25f;
327 
328             //填充表格内容 第十一行
329 
330             newTable.Cell(11, 1).Range.Text = "教育背景";
331             newTable.Cell(11, 1).Merge(newTable.Cell(18, 1));
332             newTable.Cell(11, 2).Range.Text = "说  明";
333             newTable.Cell(11, 2).Merge(newTable.Cell(11, 3));
334             newTable.Cell(11, 3).Range.Text = "学习方式:1.统招;2.电大、夜大、函授、自考、成人(教育部承认学历);3.党校;                       请在“学习方式”一栏中填入。如无此教育背景则对应行信息不填。";
335             newTable.Cell(11, 3).Merge(newTable.Cell(11, 14));
336 
337 
338             //填充表格内容 第十二行
339 
340             newTable.Cell(12, 2).Range.Text = "学  历";
341             newTable.Cell(12, 2).Merge(newTable.Cell(12, 3));
342             newTable.Cell(12, 3).Range.Text = "学 位";
343             newTable.Cell(12, 3).Merge(newTable.Cell(12, 5));
344             newTable.Cell(12, 4).Range.Text = "学习方式";
345             newTable.Cell(12, 5).Range.Text = "毕业院校";
346             newTable.Cell(12, 5).Merge(newTable.Cell(12, 8));
347             newTable.Cell(12, 6).Range.Text = "专 业";
348             newTable.Cell(12, 6).Merge(newTable.Cell(12, 7));
349             newTable.Cell(12, 7).Range.Text = "就读起止时间";
350             newTable.Cell(12, 7).Merge(newTable.Cell(12, 8));
351 
352             //填充表格内容 第13行
353             newTable.Cell(13, 2).Range.Text = "高  中/中  专";
354             newTable.Cell(13, 2).Merge(newTable.Cell(13, 3));
355             if (getXueLi("高中").Rows.Count > 0)
356             {
357                 System.Data.DataRow dr = getXueLi("高中").Rows[0];
358                 newTable.Cell(13, 3).Range.Text = dr["xuewei"].ToString();
359                 newTable.Cell(13, 3).Merge(newTable.Cell(13, 5));
360                 newTable.Cell(13, 4).Range.Text = dr["xuexifs"].ToString();
361                 newTable.Cell(13, 5).Range.Text = dr["xuexiaoname"].ToString();
362                 newTable.Cell(13, 5).Merge(newTable.Cell(13, 8));
363                 newTable.Cell(13, 6).Range.Text = dr["zhuanye"].ToString();
364                 newTable.Cell(13, 6).Merge(newTable.Cell(13, 7));
365                 newTable.Cell(13, 7).Range.Text = DateTime.Parse(dr["t1"].ToString()).ToString("yyyy.MM")
366                     + "" + DateTime.Parse(dr["t2"].ToString()).ToString("yyyy.MM");
367 
368                 newTable.Cell(13, 7).Merge(newTable.Cell(13, 8));
369             }
370             else
371             {
372                 newTable.Cell(13, 3).Range.Text = "";
373                 newTable.Cell(13, 3).Merge(newTable.Cell(13, 5));
374                 newTable.Cell(13, 4).Range.Text = "";
375                 newTable.Cell(13, 5).Range.Text = "";
376                 newTable.Cell(13, 5).Merge(newTable.Cell(13, 8));
377                 newTable.Cell(13, 6).Range.Text = "";
378                 newTable.Cell(13, 6).Merge(newTable.Cell(13, 7));
379                 newTable.Cell(13, 7).Range.Text = "";
380                 newTable.Cell(13, 7).Merge(newTable.Cell(13, 8));
381             }
382 
383 
384 
385             //填充表格内容 第14行
386 
387             newTable.Cell(14, 2).Range.Text = "大  专";
388             newTable.Cell(14, 2).Merge(newTable.Cell(14, 3));
389             newTable.Cell(14, 2).Select();//选中一行 
390             WordApp.Selection.ParagraphFormat.LineSpacing = 25f;
391             if (getXueLi("大专").Rows.Count > 0)
392             {
393                 System.Data.DataRow dr = getXueLi("大专").Rows[0];
394                 newTable.Cell(14, 3).Range.Text = dr["xuewei"].ToString();
395                 newTable.Cell(14, 3).Merge(newTable.Cell(14, 5));
396                 newTable.Cell(14, 4).Range.Text = dr["xuexifs"].ToString();
397                 newTable.Cell(14, 5).Range.Text = dr["xuexiaoname"].ToString();
398                 newTable.Cell(14, 5).Merge(newTable.Cell(14, 8));
399                 newTable.Cell(14, 6).Range.Text = dr["zhuanye"].ToString();
400                 newTable.Cell(14, 6).Merge(newTable.Cell(14, 7));
401                 newTable.Cell(14, 7).Range.Text = DateTime.Parse(dr["t1"].ToString()).ToString("yyyy.MM")
402                     + "" + DateTime.Parse(dr["t2"].ToString()).ToString("yyyy.MM");
403                 newTable.Cell(14, 7).Merge(newTable.Cell(14, 8));
404             }
405             else
406             {
407                 newTable.Cell(14, 3).Range.Text = "";
408                 newTable.Cell(14, 3).Merge(newTable.Cell(14, 5));
409                 newTable.Cell(14, 4).Range.Text = "";
410                 newTable.Cell(14, 5).Range.Text = "";
411                 newTable.Cell(14, 5).Merge(newTable.Cell(14, 8));
412                 newTable.Cell(14, 6).Range.Text = "";
413                 newTable.Cell(14, 6).Merge(newTable.Cell(14, 7));
414                 newTable.Cell(14, 7).Range.Text = "";
415                 newTable.Cell(14, 7).Merge(newTable.Cell(14, 8));
416             }
417 
418 
419 
420             //填充表格内容 第15行
421 
422             newTable.Cell(15, 2).Range.Text = "本  科";
423             newTable.Cell(15, 2).Merge(newTable.Cell(15, 3));
424             newTable.Cell(15, 2).Select();//选中一行 
425             WordApp.Selection.ParagraphFormat.LineSpacing = 25f;
426             if (getXueLi("本科").Rows.Count > 0)
427             {
428                 System.Data.DataRow dr = getXueLi("本科").Rows[0];
429                 newTable.Cell(15, 3).Range.Text = dr["xuewei"].ToString();
430                 newTable.Cell(15, 3).Merge(newTable.Cell(15, 5));
431                 newTable.Cell(15, 4).Range.Text = dr["xuexifs"].ToString();
432                 newTable.Cell(15, 5).Range.Text = dr["xuexiaoname"].ToString();
433                 newTable.Cell(15, 5).Merge(newTable.Cell(15, 8));
434                 newTable.Cell(15, 6).Range.Text = dr["zhuanye"].ToString();
435                 newTable.Cell(15, 6).Merge(newTable.Cell(15, 7));
436                 newTable.Cell(15, 7).Range.Text = DateTime.Parse(dr["t1"].ToString()).ToString("yyyy.MM") +
437                     "" + DateTime.Parse(dr["t2"].ToString()).ToString("yyyy.MM");
438                 newTable.Cell(15, 7).Merge(newTable.Cell(15, 8));
439             }
440             else
441             {
442                 newTable.Cell(15, 3).Range.Text = "";
443                 newTable.Cell(15, 3).Merge(newTable.Cell(15, 5));
444                 newTable.Cell(15, 4).Range.Text = "";
445                 newTable.Cell(15, 5).Range.Text = "";
446                 newTable.Cell(15, 5).Merge(newTable.Cell(15, 8));
447                 newTable.Cell(15, 6).Range.Text = "";
448                 newTable.Cell(15, 6).Merge(newTable.Cell(15, 7));
449                 newTable.Cell(15, 7).Range.Text = "";
450                 newTable.Cell(15, 7).Merge(newTable.Cell(15, 8));
451             }
452 
453 
454             //填充表格内容 第16行
455 
456             newTable.Cell(16, 2).Range.Text = "第二学士    学位班";
457             newTable.Cell(16, 2).Merge(newTable.Cell(16, 3));
458             if (getXueLi("第二学士学位班").Rows.Count > 0)
459             {
460                 System.Data.DataRow dr = getXueLi("第二学士学位班").Rows[0];
461                 newTable.Cell(16, 3).Range.Text = dr["xuewei"].ToString();
462                 newTable.Cell(16, 3).Merge(newTable.Cell(16, 5));
463                 newTable.Cell(16, 4).Range.Text = dr["xuexifs"].ToString();
464                 newTable.Cell(16, 5).Range.Text = dr["xuexiaoname"].ToString();
465                 newTable.Cell(16, 5).Merge(newTable.Cell(16, 8));
466                 newTable.Cell(16, 6).Range.Text = dr["zhuanye"].ToString();
467                 newTable.Cell(16, 6).Merge(newTable.Cell(16, 7));
468                 newTable.Cell(16, 7).Range.Text = DateTime.Parse(dr["t1"].ToString()).ToString("yyyy.MM") +
469                     "" + DateTime.Parse(dr["t2"].ToString()).ToString("yyyy.MM");
470                 newTable.Cell(16, 7).Merge(newTable.Cell(16, 8));
471 
472 
473             }
474             else
475             {
476                 newTable.Cell(16, 3).Range.Text = "";
477                 newTable.Cell(16, 3).Merge(newTable.Cell(16, 5));
478                 newTable.Cell(16, 4).Range.Text = "";
479                 newTable.Cell(16, 5).Range.Text = "";
480                 newTable.Cell(16, 5).Merge(newTable.Cell(16, 8));
481                 newTable.Cell(16, 6).Range.Text = "";
482                 newTable.Cell(16, 6).Merge(newTable.Cell(16, 7));
483                 newTable.Cell(16, 7).Range.Text = "";
484                 newTable.Cell(16, 7).Merge(newTable.Cell(16, 8));
485             }
486 
487 
488             //填充表格内容 第17行
489 
490             newTable.Cell(17, 2).Range.Text = "硕  士        研究生";
491             newTable.Cell(17, 2).Merge(newTable.Cell(17, 3));
492             if (getXueLi("硕士研究生").Rows.Count > 0)
493             {
494                 System.Data.DataRow dr = getXueLi("硕士研究生").Rows[0];
495                 newTable.Cell(17, 3).Range.Text = dr["xuewei"].ToString();
496                 newTable.Cell(17, 3).Merge(newTable.Cell(17, 5));
497                 newTable.Cell(17, 4).Range.Text = dr["xuexifs"].ToString();
498                 newTable.Cell(17, 5).Range.Text = dr["xuexiaoname"].ToString();
499                 newTable.Cell(17, 5).Merge(newTable.Cell(17, 8));
500                 newTable.Cell(17, 6).Range.Text = dr["zhuanye"].ToString();
501                 newTable.Cell(17, 6).Merge(newTable.Cell(17, 7));
502                 newTable.Cell(17, 7).Range.Text = DateTime.Parse(dr["t1"].ToString()).ToString("yyyy.MM") +
503                     "" + DateTime.Parse(dr["t2"].ToString()).ToString("yyyy.MM");
504                 newTable.Cell(17, 7).Merge(newTable.Cell(17, 8));
505 
506 
507             }
508             else
509             {
510                 newTable.Cell(17, 3).Range.Text = "";
511                 newTable.Cell(17, 3).Merge(newTable.Cell(17, 5));
512                 newTable.Cell(17, 4).Range.Text = "";
513                 newTable.Cell(17, 5).Range.Text = "";
514                 newTable.Cell(17, 5).Merge(newTable.Cell(17, 8));
515                 newTable.Cell(17, 6).Range.Text = "";
516                 newTable.Cell(17, 6).Merge(newTable.Cell(17, 7));
517                 newTable.Cell(17, 7).Range.Text = "";
518                 newTable.Cell(17, 7).Merge(newTable.Cell(17, 8));
519             }
520 
521 
522             //    填充表格内容 第18行
523 
524             newTable.Cell(18, 2).Range.Text = "博  士        研究生";
525             newTable.Cell(18, 2).Merge(newTable.Cell(18, 3));
526             if (getXueLi("博士研究生").Rows.Count > 0)
527             {
528                 System.Data.DataRow dr = getXueLi("博士研究生").Rows[0];
529                 newTable.Cell(18, 3).Range.Text = dr["xuewei"].ToString();
530                 newTable.Cell(18, 3).Merge(newTable.Cell(18, 5));
531                 newTable.Cell(18, 4).Range.Text = dr["xuexifs"].ToString();
532                 newTable.Cell(18, 5).Range.Text = dr["xuexiaoname"].ToString();
533                 newTable.Cell(18, 5).Merge(newTable.Cell(18, 8));
534                 newTable.Cell(18, 6).Range.Text = dr["zhuanye"].ToString();
535                 newTable.Cell(18, 6).Merge(newTable.Cell(18, 7));
536                 newTable.Cell(18, 7).Range.Text = DateTime.Parse(dr["t1"].ToString()).ToString("yyyy.MM") +
537                      "" + DateTime.Parse(dr["t2"].ToString()).ToString("yyyy.MM");
538                 newTable.Cell(18, 7).Merge(newTable.Cell(18, 8));
539 
540 
541             }
542             else
543             {
544                 newTable.Cell(18, 3).Range.Text = "";
545                 newTable.Cell(18, 3).Merge(newTable.Cell(18, 5));
546                 newTable.Cell(18, 4).Range.Text = "";
547                 newTable.Cell(18, 5).Range.Text = "";
548                 newTable.Cell(18, 5).Merge(newTable.Cell(18, 8));
549                 newTable.Cell(18, 6).Range.Text = "";
550                 newTable.Cell(18, 6).Merge(newTable.Cell(18, 7));
551                 newTable.Cell(18, 7).Range.Text = "";
552                 newTable.Cell(18, 7).Merge(newTable.Cell(18, 8));
553             }
554 
555 
556             //    填充表格内容 第19行
557 
558             newTable.Cell(19, 1).Range.Text = "技术职称";
559             newTable.Cell(19, 1).Merge(newTable.Cell(19, 2));
560             newTable.Cell(19, 2).Range.Text = dat.Rows[0]["zhicheng"].ToString();
561             newTable.Cell(19, 2).Merge(newTable.Cell(19, 5));
562             newTable.Cell(19, 3).Range.Text = "职业资格";
563             newTable.Cell(19, 3).Merge(newTable.Cell(19, 4));
564             newTable.Cell(19, 4).Range.Text = dat.Rows[0]["renzhizige"].ToString();
565             newTable.Cell(19, 4).Merge(newTable.Cell(19, 6));
566             newTable.Cell(19, 5).Range.Text = "其他资质及培训证书等";
567             newTable.Cell(19, 5).Merge(newTable.Cell(19, 6));
568             newTable.Cell(19, 6).Range.Text = dat.Rows[0]["zhengshu"].ToString();
569             newTable.Cell(19, 6).Merge(newTable.Cell(19, 7));
570 
571 
572             WordApp.ActiveDocument.PageSetup.SectionStart = Microsoft.Office.Interop.Word.WdSectionStart.wdSectionNewPage;//节的起始位置:新建页
573 
574             newTable.Cell(19, 1).Select();//选中一行 
575             //  WordApp.Selection.ParagraphFormat.LineSpacing = 25f; 
576             object missing1 = System.Reflection.Missing.Value;
577             object count1 = 20;
578             object WdLine1 = Microsoft.Office.Interop.Word.WdUnits.wdLine;//换一行;   
579             WordApp.Selection.MoveDown(ref WdLine1, ref count1, ref missing1);//光标向下移1行   
580             WordApp.Selection.MoveDown(ref WdLine1, ref count1, ref missing1);//光标向下移1行   
581             WordApp.Selection.TypeParagraph();//在表格外回车  
582            583 
584             //文档中创建表格 
585             Microsoft.Office.Interop.Word.Table newTable1 = WordDoc.Tables.Add(WordApp.Selection.Range, 17, 9, ref Nothing, ref Nothing);
586           587            588             //设置表格框
589             newTable1.Borders.OutsideLineStyle = Microsoft.Office.Interop.Word.WdLineStyle.wdLineStyleSingle;
590             newTable1.Columns[1].Width = 25f;
591             newTable1.Columns[2].Width = 40f;
592             newTable1.Columns[3].Width = 40f;
593             newTable1.Columns[4].Width = 30f;
594             newTable1.Columns[5].Width = 50f;
595             newTable1.Columns[6].Width = 70f;
596             newTable1.Columns[7].Width = 70f;
597             newTable1.Columns[8].Width = 130f;
598             newTable1.Columns[9].Width = 90f;
599 
600             newTable1.Cell(1, 1).Range.Bold = 2;//设置单元格中字体为粗体 
601 
602             WordApp.Selection.ParagraphFormat.LineSpacing = 10.5f;
603 
604             WordApp.Selection.Cells.VerticalAlignment = Microsoft.Office.Interop.Word.WdCellVerticalAlignment.wdCellAlignVerticalCenter;//垂直居中 
605             WordApp.Selection.ParagraphFormat.Alignment = Microsoft.Office.Interop.Word.WdParagraphAlignment.wdAlignParagraphCenter;//水平居中 
606             //填充表格内容 
607             for (int i = 1; i < 15; i++)
608             {
609                 newTable1.Rows.Borders.OutsideLineStyle = Microsoft.Office.Interop.Word.WdLineStyle.wdLineStyleSingle;
610 
611             }
612             for (int i = 1; i < 9; i++)
613             {
614                 newTable1.Columns.Borders.OutsideLineStyle = Microsoft.Office.Interop.Word.WdLineStyle.wdLineStyleSingle;
615 
616             }
617 
618           
621             WordApp.Selection.MoveEnd(ref unit, ref countjz);
622             WordApp.Selection.Cells.VerticalAlignment = Microsoft.Office.Interop.Word.WdCellVerticalAlignment.wdCellAlignVerticalCenter;//垂直居中 
623 
624 
625             //填充表格内容 第1行
626             newTable1.Cell(1, 1).Range.Text = "工作经历";
627             newTable1.Cell(1, 1).Merge(newTable1.Cell(8, 1));
628             newTable1.Cell(1, 2).Range.Text = "说  明";
629             newTable1.Cell(1, 2).Merge(newTable1.Cell(1, 3));
630             newTable1.Cell(1, 3).Range.Text = "1、请按工作时间由近至远(倒序)填写;                                                    2、如在同一家公司因岗位、级别、地点发生变化请予以证明,详细填写。";
631             newTable1.Cell(1, 3).Merge(newTable1.Cell(1, 8));
632 
633             //填充表格内容 第2行
634             newTable1.Cell(2, 2).Range.Text = "起止时间 (精确到月)";
635             newTable1.Cell(2, 2).Merge(newTable1.Cell(2, 4));
636             newTable1.Cell(2, 3).Range.Text = "单位名称";
637             newTable1.Cell(2, 3).Merge(newTable1.Cell(2, 4));
638             newTable1.Cell(2, 4).Range.Text = "岗 位/职 务";
639             newTable1.Cell(2, 5).Range.Text = "主要职责(20字以内)";
640             newTable1.Cell(2, 6).Range.Text = "证明人/联系方式";
641 
642             string sqlgz = "select  * from hr_quanzhigongzuo where  id in ( select top 6 " +
643            "  id from hr_quanzhigongzuo where uid='" + uid + "'   order by id desc )  order by id asc ";
644             DataTable datgz = ZWL.DBUtility.MyDBHelp.GetDataTable(sqlgz);
645             if (datgz.Rows.Count > 0)
646             {
647 
648                 for (int i = 0; i < datgz.Rows.Count; i++)
649                 {
650                     newTable1.Cell(i + 3, 2).Range.Text = DateTime.Parse(datgz.Rows["t1"].ToString()).ToString("yyyy.MM") + "" +
651                         DateTime.Parse(datgz.Rows["t2"].ToString()).ToString("yyyy.MM");
652                     newTable1.Cell(i + 3, 2).Merge(newTable1.Cell(i + 3, 4));
653                     newTable1.Cell(i + 3, 3).Range.Text = datgz.Rows["gongzuodanwei"].ToString();
654                     newTable1.Cell(i + 3, 3).Merge(newTable1.Cell(i + 3, 4));
655                     newTable1.Cell(i + 3, 4).Range.Text = datgz.Rows["zhiwu"].ToString();
656                     newTable1.Cell(i + 3, 5).Range.Text = datgz.Rows["zhuyao"].ToString();
657                     newTable1.Cell(i + 3, 6).Range.Text = datgz.Rows["zhengming"].ToString();
658                 }
659 
660                 for (int i = datgz.Rows.Count + 3; i < 9; i++)
661                 {
662                     newTable1.Cell(i, 2).Range.Text = "";
663                     newTable1.Cell(i, 2).Merge(newTable1.Cell(i, 4));
664                     newTable1.Cell(i, 2).Select();//选中一行 
665                     WordApp.Selection.ParagraphFormat.LineSpacing = 25f;
666                     newTable1.Cell(i, 3).Range.Text = "";
667                     newTable1.Cell(i, 3).Merge(newTable1.Cell(i, 4));
668                     newTable1.Cell(i, 4).Range.Text = "";
669                     newTable1.Cell(i, 5).Range.Text = "";
670                     newTable1.Cell(i, 6).Range.Text = "";
671                 }
672 
673             }
674             else
675             {
676                 for (int i = 3; i < 9; i++)
677                 {
678                     newTable1.Cell(i, 2).Range.Text = "";
679                     newTable1.Cell(i, 2).Merge(newTable1.Cell(i, 4));
680                     newTable1.Cell(i, 2).Select();//选中一行 
681                     WordApp.Selection.ParagraphFormat.LineSpacing = 25f;
682                     newTable1.Cell(i, 3).Range.Text = "";
683                     newTable1.Cell(i, 3).Merge(newTable1.Cell(i, 4));
684                     newTable1.Cell(i, 4).Range.Text = "";
685                     newTable1.Cell(i, 5).Range.Text = "";
686                     newTable1.Cell(i, 6).Range.Text = "";
687                 }
688 
689             }
690 
691             //填充表格内容 第9行
692             newTable1.Cell(9, 1).Range.Text = "家庭成员";
693             newTable1.Cell(9, 1).Merge(newTable1.Cell(12, 1));
694             newTable1.Cell(9, 2).Range.Text = "关  系";
695             newTable1.Cell(9, 2).Merge(newTable1.Cell(9, 4));
696             newTable1.Cell(9, 2).Select();//选中一行 
697             WordApp.Selection.ParagraphFormat.LineSpacing = 25f;
698             //WordApp.Selection.MoveDown(ref WdLine1, ref count1, ref missing1);//光标向下移1行   
699 
700 
701 
702             newTable1.Cell(9, 3).Range.Text = "姓  名";
703             newTable1.Cell(9, 4).Range.Text = "出生日期";
704             newTable1.Cell(9, 5).Range.Text = "政治面貌";
705             newTable1.Cell(9, 6).Range.Text = "工作单位及职务(如退休填写退休前单位)";
706             newTable1.Cell(9, 6).Merge(newTable1.Cell(9, 7));
707 
708             string sqljt = " select top 3  * from hr_jiating where uid='" + uid + "'     ";
709             DataTable datjt = ZWL.DBUtility.MyDBHelp.GetDataTable(sqljt);
710 
711             if (datjt.Rows.Count > 0)
712             {
713 
714                 for (int i = 0; i < datjt.Rows.Count; i++)
715                 {
716                     newTable1.Cell(i + 10, 2).Range.Text = datjt.Rows["guanli"].ToString();
717                     newTable1.Cell(i + 10, 2).Merge(newTable1.Cell(i + 10, 4));
718                     newTable1.Cell(i + 10, 2).Select();//选中一行 
719                     WordApp.Selection.ParagraphFormat.LineSpacing = 25f;
720                     newTable1.Cell(i + 10, 3).Range.Text = datjt.Rows["name"].ToString();
721                     newTable1.Cell(i + 10, 4).Range.Text = DateTime.Parse(datjt.Rows["createdate"].ToString()).ToString("yyyy.MM");
722                     newTable1.Cell(i + 10, 5).Range.Text = datjt.Rows["zhengzhi"].ToString();
723                     newTable1.Cell(i + 10, 6).Range.Text = datjt.Rows["gongzuodanwei"].ToString();
724                     newTable1.Cell(i + 10, 6).Merge(newTable1.Cell(i + 10, 7));
725                 }
726 
727                 for (int i = datjt.Rows.Count + 10; i < 13; i++)
728                 {
729                     newTable1.Cell(i, 2).Range.Text = "";
730                     newTable1.Cell(i, 2).Merge(newTable1.Cell(i, 4));
731                     newTable1.Cell(i, 2).Select();//选中一行 
732                     WordApp.Selection.ParagraphFormat.LineSpacing = 25f;
733                     newTable1.Cell(i, 3).Range.Text = "";
734                     newTable1.Cell(i, 4).Range.Text = "";
735                     newTable1.Cell(i, 5).Range.Text = "";
736                     newTable1.Cell(i, 6).Range.Text = "";
737                     newTable1.Cell(i, 6).Merge(newTable1.Cell(i, 7));
738                 }
739 
740             }
741             else
742             {
743                 for (int i = 10; i < 13; i++)
744                 {
745                     newTable1.Cell(i, 2).Range.Text = "";
746                     newTable1.Cell(i, 2).Merge(newTable1.Cell(i, 4));
747                     newTable1.Cell(i, 2).Select();//选中一行 
748                     WordApp.Selection.ParagraphFormat.LineSpacing = 25f;
749                     newTable1.Cell(i, 3).Range.Text = "";
750                     newTable1.Cell(i, 4).Range.Text = "";
751                     newTable1.Cell(i, 5).Range.Text = "";
752                     newTable1.Cell(i, 6).Range.Text = "";
753                     newTable1.Cell(i, 6).Merge(newTable1.Cell(i, 7));
754                 }
755 
756             }
757 
758             //填充表格内容 第13行
759             newTable1.Cell(13, 1).Range.Text = "自我鉴定";
760             newTable1.Cell(13, 2).Range.Text = dat.Rows[0]["jianding"].ToString();
761             newTable1.Cell(13, 2).Merge(newTable1.Cell(13, 9));
762 
763             //填充表格内容 第14行
764             newTable1.Cell(14, 1).Range.Text = "劳动合同签订情况";
765             newTable1.Cell(14, 1).Merge(newTable1.Cell(14, 4));
766             if (dat.Rows[0]["iflizhi"].ToString().Equals("1"))
767             {
768                 newTable1.Cell(14, 2).Range.Text = "√目前与其他单位不存在劳动关系;                                           " +
769                     "□目前与原单位尚未解除劳动合同,但承诺最迟在到岗时可以提供解除劳动合同证明;" +
770                     "□其他(请说明)";
771             }
772             else if (dat.Rows[0]["iflizhi"].ToString().Equals("2"))
773             {
774                 newTable1.Cell(14, 2).Range.Text = "□目前与其他单位不存在劳动关系;                                           " +
775                     "√目前与原单位尚未解除劳动合同,但承诺最迟在到岗时可以提供解除劳动合同证明;" +
776                     "□其他(请说明)";
777             }
778             else
779             {
780                 newTable1.Cell(14, 2).Range.Text = "□目前与其他单位不存在劳动关系;                                           " +
781                     "□目前与原单位尚未解除劳动合同,但承诺最迟在到岗时可以提供解除劳动合同证明;" +
782                     "√其他(" + dat.Rows[0]["iflizhi"].ToString() + ")";
783             }
784             newTable1.Cell(14, 2).Merge(newTable1.Cell(14, 6));
785 
786             string sqlyp = " select date from hr_yingpin where uid = '" + uid + "'";
787             string nian = "";
788             DataTable datyp = ZWL.DBUtility.MyDBHelp.GetDataTable(sqlyp);
789             if (datyp.Rows.Count > 0)
790             {
791                 nian = DateTime.Parse(datyp.Rows[0]["date"].ToString()).ToString("yyyy年MM月dd日");
792             }
793             //填充表格内容 第15行
794             newTable1.Cell(15, 1).Range.Text = "个人声明";
795             newTable1.Cell(15, 1).Merge(newTable1.Cell(15, 2));
796             newTable1.Cell(15, 1).Merge(newTable1.Cell(17, 2));
797             newTable1.Cell(15, 2).Range.Text = "    本人郑重声明,我在上述表中提的有关信息真实准确,并愿意承担因任何虚假与不实造成的一切后果;本人同意可在必要的情况下对有关信息进行核实。";
798             newTable1.Cell(15, 2).Merge(newTable1.Cell(15, 8));
799 
800             //填充表格内容 第16行
801 
802             newTable1.Cell(16, 2).Range.Text = "     此外,我清楚以下事实:如果在30天内没有接到面试通知,本次申请可能失效,个人简历将进入公司人才库,不予退回。";
803             newTable1.Cell(16, 2).Merge(newTable1.Cell(16, 8));
804 
805             //填充表格内容 第17行
806 
807             newTable1.Cell(17, 2).Range.Text = "                                         应聘者签名:" + dat.Rows[0]["name"].ToString() + "              " + nian;
808             newTable1.Cell(17, 2).Merge(newTable1.Cell(17, 8));
809 
810             object saveOption = Microsoft.Office.Interop.Word.WdSaveOptions.wdDoNotSaveChanges;
811             WordDoc.SaveAs(ref filename, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing, ref Nothing);
812             WordDoc.Close(ref Nothing, ref Nothing, ref Nothing);
813             WordApp.Application.Quit(ref saveOption, ref Nothing, ref Nothing);
814             WordDoc = null;
815             WordApp = null;
816             killAllProcess();
817             message = name + "文档生成成功,";
818         //}
819         //catch
820         //{
821         //    message = "文件导出异常!";
822         //}
823         return message;
824     }
825     public DataTable getXueLi(string xueli)
826     {
827         string sql = "select * from hr_jiaoyu where  uid='" + dat.Rows[0]["id"].ToString() + "' and xueli ='" + xueli + "'  ";
828         DataTable datxue = ZWL.DBUtility.MyDBHelp.GetDataTable(sql);
829         return datxue;
830     }
831     protected void killAllProcess() // 杀掉所有winword.exe进程 
832     {
833         System.Diagnostics.Process[] myPs;
834         myPs = System.Diagnostics.Process.GetProcesses();
835         foreach (System.Diagnostics.Process p in myPs)
836         {
837             if (p.Id != 0)
838             {
839                 string myS = "WINWORD.EXE" + p.ProcessName + " ID:" + p.Id.ToString();
840                 try
841                 {
842                     if (p.Modules != null)
843                         if (p.Modules.Count > 0)
844                         {
845                             System.Diagnostics.ProcessModule pm = p.Modules[0];
846                             myS += "\n Modules[0].FileName:" + pm.FileName;
847                             myS += "\n Modules[0].ModuleName:" + pm.ModuleName;
848                             myS += "\n Modules[0].FileVersionInfo:\n" + pm.FileVersionInfo.ToString();
849                             if (pm.ModuleName.ToLower() == "winword.exe")
850                                 p.Kill();
851                         }
852                 }
853                 catch
854                 { }
855                 finally
856                 {
857                 }
858             }
859         }
860     }
861     public bool IsReusable
862     {
863         get
864         {
865             return false;
866         }
867     }
868 
869 }

调用方法:

 1 private void Export(string id)
 2     {
 3         string wjname =DateTime.Now.ToString("yyyyMMddhhmmssfff");
 4         string filepath = Server.MapPath("./ReportFile/") + wjname;
 5         Directory.CreateDirectory(filepath);  //创建文件所在目录 
 6         ExportWord dao = new ExportWord();
 7         if (id.IndexOf(',') > -1)
 8         {
 9 
10             string[] strs = id.Split(',');
11             for (int i = 0; i < strs.Length; i++)
12             {
13                 string sql = " select name from hr_person where id =" + strs;
14                 DataTable dat = ZWL.DBUtility.MyDBHelp.GetDataTable(sql);
15                 dao.ProcessRequest(Context, strs, filepath + "/" + dat.Rows[0]["name"].ToString() +i+ ".doc");
16             }
17              //多个ID,所以这边调用压缩方法
18             DirectoryToZip(filepath, Server.MapPath("./ReportFile/" + wjname + ".zip"));
19             Response.Write("<script>window.location='ReportFile/" + wjname + ".zip'</script>");
20 
21         }
22         else
23         {
24             string sql = " select name from hr_person where id =" + id;
25             DataTable dat = ZWL.DBUtility.MyDBHelp.GetDataTable(sql);
26             dao.ProcessRequest(Context, id, filepath + "/"  +dat.Rows[0]["name"].ToString() + ".doc");
27             Response.Write("<script>window.location='ReportFile/" + wjname+"/" + dat.Rows[0]["name"].ToString() + ".doc'</script>");
28 
29         }
30 
31     }
32     //【filepath想要压缩文件的地址】
33     //【zippath输出压缩文件的地址】
34     private void DirectoryToZip(string path, string address)
35     {
36         //获取当前文件夹中所有的文件
37         string[] filenames = Directory.GetFiles(path);
38         Crc32 crc = new Crc32();
39         //创建输出文件(ZIP格式的文件)
40         ZipOutputStream zos = new ZipOutputStream(File.Create(address));
41         zos.SetLevel(6);
42         //遍历所有的文件
43         foreach (string name in filenames)
44         {
45             FileStream fs = File.OpenRead(name);
46             byte[] buffer = new byte[fs.Length];
47             //读取文件
48             fs.Read(buffer, 0, Convert.ToInt32(fs.Length));
49             //获取文件的文件名称和后缀名
50             string file = Path.GetFileName(name);
51             //输出文件的名称
52             ZipEntry entry = new ZipEntry(file);
53             crc.Reset();
54             crc.Update(buffer);
55             entry.Crc = crc.Value;
56             zos.PutNextEntry(entry);
57             zos.Write(buffer, 0, Convert.ToInt32(fs.Length));
58             fs.Close();
59         }
60         zos.Finish();
61         zos.Close();
62     }

有什么问大家可以讨论,讨论,我也只是研究了一周,有许多都是 ,网上找其他人的,代码是长了点,但是只要把前面的看懂了就行,后面的只是重复前面的代码,效果如图片

c#(.net) 导出 word表格_第1张图片

c#(.net) 导出 word表格_第2张图片

c#(.net) 导出 word表格_第3张图片

c#(.net) 导出 word表格_第4张图片

 

你可能感兴趣的:(.net)