收藏 分销(赏)

C#编写的Word操作类,有换页,添加表格,文竟δdoc.doc

上传人:pc****0 文档编号:7818673 上传时间:2025-01-19 格式:DOC 页数:15 大小:326KB
下载 相关 举报
C#编写的Word操作类,有换页,添加表格,文竟δdoc.doc_第1页
第1页 / 共15页
C#编写的Word操作类,有换页,添加表格,文竟δdoc.doc_第2页
第2页 / 共15页
C#编写的Word操作类,有换页,添加表格,文竟δdoc.doc_第3页
第3页 / 共15页
C#编写的Word操作类,有换页,添加表格,文竟δdoc.doc_第4页
第4页 / 共15页
C#编写的Word操作类,有换页,添加表格,文竟δdoc.doc_第5页
第5页 / 共15页
点击查看更多>>
资源描述

1、using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Data;using System.Drawing;using Word = Microsoft.Office.Interop.Word;using Microsoft.Office.Interop.Word;using System.Windows.Forms;/* * 文件名 : * * 声明: * * 创建者 : 黄聪* * 创建日期 : 2009.10.8* * 修改者 : 黄聪* * 最新修改日期

2、 : 2009.10.8*/namespace Tool/* * 类名 : WordPlayer* * 声明 : * * 创建者 : 黄聪* * 创建日期 : 2009.7.15* * 修改者 : 黄聪* * 最新修改日期 : 2009.7.15*/public class WordPlayer#region - 属性 -private static Microsoft.Office.Interop.Word._Application oWord = null;private static Microsoft.Office.Interop.Word._Document odoc = null;

3、private static Microsoft.Office.Interop.Word._Document oDocgetif (odoc = null)odoc = oWord.Documents.Add(ref Nothing, ref Nothing, ref Nothing, ref Nothing);return odoc;setif (value != null)odoc = value;private static object Nothing = System.Reflection.Missing.Value;public enum Orientation横板,竖板publi

4、c enum Alignment左对齐,居中,右对齐#endregion#region - 添加文档 -#region - 创建并打开一个空的word文档进行编辑 -public static void OpenNewWordFileToEdit()oDoc = oWord.Documents.Add(ref Nothing, ref Nothing, ref Nothing, ref Nothing);#endregion#endregion#region - 创建新Word -public static bool CreateWord(bool isVisible)tryoWord = n

5、ew Microsoft.Office.Interop.Word.Application();oWord.Visible = isVisible;return true;catch (Exception)return false;public static bool CreateWord()return CreateWord(false);#endregion#region - 打开文档 -public static bool Open(string filePath, bool isVisible)tryoWord.Visible = isVisible;object path = file

6、Path;oDoc = oWord.Documents.Open(ref path,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);return true;catch (Exception)return false;#endregion#region - 插入表

7、格 -public static bool InsertTable(DataTable dt, bool haveBorder, double colWidths)tryobject Nothing = System.Reflection.Missing.Value;int lenght = oDoc.Characters.Count - 1;object start = lenght;object end = lenght;/表格起始坐标Microsoft.Office.Interop.Word.Range tableLocation = oDoc.Range(ref start, ref

8、end);/添加Word表格 Microsoft.Office.Interop.Word.Table table = oDoc.Tables.Add(tableLocation, dt.Rows.Count, dt.Columns.Count, ref Nothing, ref Nothing);if (colWidths != null)for (int i = 0; i colWidths.Length; i+)table.Columnsi + 1.Width = (float)(28.5F * colWidthsi);/设置TABLE的样式table.Rows.HeightRule =

9、Microsoft.Office.Interop.Word.WdRowHeightRule.wdRowHeightAtLeast;table.Rows.Height = oWord.CentimetersToPoints(float.Parse(0.8);table.Range.Font.Size = 10.5F;table.Range.Font.Name = 宋体;table.Range.Font.Bold = 0;table.Range.ParagraphFormat.Alignment = Microsoft.Office.Interop.Word.WdParagraphAlignmen

10、t.wdAlignParagraphCenter;table.Range.Cells.VerticalAlignment = Microsoft.Office.Interop.Word.WdCellVerticalAlignment.wdCellAlignVerticalCenter;if (haveBorder = true)/设置外框样式table.Borders.OutsideLineStyle = Microsoft.Office.Interop.Word.WdLineStyle.wdLineStyleSingle;table.Borders.InsideLineStyle = Mic

11、rosoft.Office.Interop.Word.WdLineStyle.wdLineStyleSingle;/样式设置结束for (int row = 0; row dt.Rows.Count; row+)for (int col = 0; col dt.Columns.Count; col+)table.Cell(row + 1, col + 1).Range.Text = dt.Rowsrowcol.ToString();return true;catch (Exception e)MessageBox.Show(e.ToString(), 错误提示, MessageBoxButto

12、ns.OK, MessageBoxIcon.Error);return false;finallypublic static bool InsertTable(DataTable dt, bool haveBorder)return InsertTable(dt, haveBorder, null);public static bool InsertTable(DataTable dt)return InsertTable(dt, false, null);#endregion#region - 插入文本 -public static bool InsertText(string strTex

13、t, System.Drawing.Font font, Alignment alignment, bool isAftre)tryWord.Range rng = oDoc.Content;int lenght = oDoc.Characters.Count - 1;object start = lenght;object end = lenght;rng = oDoc.Range(ref start, ref end);if (isAftre = true)strText += rn;rng.Text = strText;rng.Font.Name = font.Name;rng.Font

14、.Size = font.Size;if (font.Style = FontStyle.Bold) rng.Font.Bold = 1; /设置单元格中字体为粗体SetAlignment(rng, alignment);return true;catch (Exception)return false;public static bool InsertText(string strText)return InsertText(strText, new System.Drawing.Font(宋体, 10.5F, FontStyle.Bold), Alignment.左对齐, false);#

15、endregion#region - 设置对齐方式 -private static Microsoft.Office.Interop.Word.WdParagraphAlignment SetAlignment(Range rng, Alignment alignment)rng.ParagraphFormat.Alignment = SetAlignment(alignment);return SetAlignment(alignment);private static Microsoft.Office.Interop.Word.WdParagraphAlignment SetAlignme

16、nt(Alignment alignment)if (alignment = Alignment.居中)return Word.WdParagraphAlignment.wdAlignParagraphCenter;else if (alignment = Alignment.左对齐)return Word.WdParagraphAlignment.wdAlignParagraphLeft;else return Word.WdParagraphAlignment.wdAlignParagraphRight; #endregion#region - 页面设置 -public static vo

17、id SetPage(Orientation orientation, double width, double height, double topMargin, double leftMargin, double rightMargin, double bottomMargin)oDoc.PageSetup.PageWidth = oWord.CentimetersToPoints(float)width);oDoc.PageSetup.PageHeight = oWord.CentimetersToPoints(float)height);if (orientation = Orient

18、ation.横板)oDoc.PageSetup.Orientation = Microsoft.Office.Interop.Word.WdOrientation.wdOrientLandscape;oDoc.PageSetup.TopMargin = (float)(topMargin * 25);/上边距 oDoc.PageSetup.LeftMargin = (float)(leftMargin * 25);/左边距 oDoc.PageSetup.RightMargin = (float)(rightMargin * 25);/右边距 oDoc.PageSetup.BottomMargi

19、n = (float)(bottomMargin * 25);/下边距public static void SetPage(Orientation orientation, double topMargin, double leftMargin, double rightMargin, double bottomMargin)SetPage(orientation, 21, 29.7, topMargin, leftMargin, rightMargin, bottomMargin);public static void SetPage(double topMargin, double lef

20、tMargin, double rightMargin, double bottomMargin)SetPage(Orientation.竖板, 21, 29.7, topMargin, leftMargin, rightMargin, bottomMargin);#endregion#region - 插入分页符 -public static void InsertBreak()Word.Paragraph para;para = oDoc.Content.Paragraphs.Add(ref Nothing);object pBreak = (int)WdBreakType.wdSecti

21、onBreakNextPage;para.Range.InsertBreak(ref pBreak);#endregion#region - 关闭当前文档 -public static bool CloseDocument()tryobject doNotSaveChanges = Word.WdSaveOptions.wdDoNotSaveChanges;oDoc.Close(ref doNotSaveChanges, ref Nothing, ref Nothing);oDoc = null;return true;catch (Exception)return false;#endreg

22、ion#region - 关闭程序 -public static bool Quit()tryobject saveOption = Word.WdSaveOptions.wdDoNotSaveChanges;oWord.Quit(ref saveOption, ref Nothing, ref Nothing);return true;catch (Exception)return false;#endregion#region - 保存文档 -public static bool Save(string savePath)return Save(savePath, false);publi

23、c static bool Save(string savePath, bool isClose)tryobject fileName = savePath;oDoc.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);

24、if (isClose)return CloseDocument();return true;catch (Exception)return false;#endregion#region - 插入页脚 -public static bool InsertPageFooter(string text, System.Drawing.Font font, WordPlayer.Alignment alignment)tryoWord.ActiveWindow.View.SeekView = Word.WdSeekView.wdSeekCurrentPageFooter;/页脚 oWord.Sel

25、ection.InsertAfter(text);GetWordFont(oWord.Selection.Font, font);SetAlignment(oWord.Selection.Range, alignment);return true;catch (Exception)return false;public static bool InsertPageFooterNumber(System.Drawing.Font font, WordPlayer.Alignment alignment)tryoWord.ActiveWindow.View.SeekView = WdSeekVie

26、w.wdSeekCurrentPageHeader;oWord.Selection.WholeStory();oWord.Selection.ParagraphFormat.BordersWdBorderType.wdBorderBottom.LineStyle = WdLineStyle.wdLineStyleNone;oWord.ActiveWindow.View.SeekView = Word.WdSeekView.wdSeekMainDocument;oWord.ActiveWindow.View.SeekView = Word.WdSeekView.wdSeekCurrentPage

27、Footer;/页脚 oWord.Selection.TypeText(第);object page = WdFieldType.wdFieldPage;oWord.Selection.Fields.Add(oWord.Selection.Range, ref page, ref Nothing, ref Nothing);oWord.Selection.TypeText(页/共);object pages = WdFieldType.wdFieldNumPages;oWord.Selection.Fields.Add(oWord.Selection.Range, ref pages, ref

28、 Nothing, ref Nothing);oWord.Selection.TypeText(页);GetWordFont(oWord.Selection.Font, font);SetAlignment(oWord.Selection.Range, alignment);oWord.ActiveWindow.View.SeekView = Word.WdSeekView.wdSeekMainDocument;return true;catch (Exception)return false;#endregion#region - 字体格式设定 -public static void Get

29、WordFont(Microsoft.Office.Interop.Word.Font wordFont, System.Drawing.Font font)wordFont.Name = font.Name;wordFont.Size = font.Size;if (font.Bold) wordFont.Bold = 1; if (font.Italic) wordFont.Italic = 1; if (font.Underline = true)wordFont.Underline = Microsoft.Office.Interop.Word.WdUnderline.wdUnderl

30、ineNone;wordFont.UnderlineColor = Microsoft.Office.Interop.Word.WdColor.wdColorAutomatic;if (font.Strikeout)wordFont.StrikeThrough = 1;/删除线#endregion#region - 获取Word中的颜色 -public static WdColor GetWordColor(Color c)UInt32 R = 0x1, G = 0x100, B = 0x10000;return (Microsoft.Office.Interop.Word.WdColor)(

31、R * c.R + G * c.G + B * c.B);#endregion新建一个窗体工程,拖入一个按钮,复制下面代码进去,按F5运行private void button2_Click(object sender, EventArgs e)if (WordPlayer.CreateWord() = false)MessageBox.Show(文件创造失败., 错误提示, MessageBoxButtons.OK, MessageBoxIcon.Error);return;DataTable storedt = new DataTable();storedt.Columns.Add(Boo

32、k_ISBN);storedt.Columns.Add(Book_Name);storedt.Columns.Add(Store_Num);storedt.Columns.Add(CanBorrow_Num);storedt.Columns.Add(InShop_Num);storedt.Columns.Add(OutShop_Num);storedt.Rows.Add(1, 1, 1, 1, 1, 1);storedt.Rows.Add(2, 2, 2, 2, 2, 2);storedt.Rows.Add(3, 3, 3, 3, 3, 3);storedt.Rows.Add(4, 4, 4,

33、 4, 4, 4);storedt.Rows.Add(5, 5, 5, 5, 5, 5);storedt.Rows.Add(6, 6, 6, 6, 6, 6);WordPlayer.SetPage(WordPlayer.Orientation.横板, 18.4, 26, 3, 2.4, 1.87, 2.1);WordPlayer.InsertText(工 资 变 动 情 况 审 批 表, new Font(微软雅黑, 14, FontStyle.Bold), WordPlayer.Alignment.居中, true);WordPlayer.InsertText(, new Font(微软雅黑

34、, 14, FontStyle.Bold), WordPlayer.Alignment.居中, true);WordPlayer.InsertText(姓名:A 审批单位:广西师范大学,new Font(宋体, 12, FontStyle.Regular), WordPlayer.Alignment.左对齐, false);WordPlayer.InsertTable(storedt, true);WordPlayer.InsertText(制表时间:2007年1月15日, new Font(宋体, 12, FontStyle.Regular), WordPlayer.Alignment.右对齐, false);WordPlayer.Save(Application.StartupPath + test.doc,true);最后效果如下:

展开阅读全文
部分上传会员的收益排行 01、路***(¥15400+),02、曲****(¥15300+),
03、wei****016(¥13200+),04、大***流(¥12600+),
05、Fis****915(¥4200+),06、h****i(¥4100+),
07、Q**(¥3400+),08、自******点(¥2400+),
09、h*****x(¥1400+),10、c****e(¥1100+),
11、be*****ha(¥800+),12、13********8(¥800+)。
相似文档                                   自信AI助手自信AI助手
搜索标签

当前位置:首页 > 百科休闲 > 其他

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服