C# : 操作Word文件的API - (将C# source中的xml注释转换成word文档)
这篇博客将要讨论的是关于:
如何从C#的source以及注释, 生成一份Word格式的关于各个类,函数以及成员变量的说明文档.
他的大背景如下......
最近的一个项目使用C#, 分N个模块,
在项目的里程碑的时候, 日本的总公司要检查我们的成果物.
成果物包括源代码, 概要设计式样书(SD,System Design), 详细设计式样书(PD, Program Design), 自动化测试等等.
源代码必须要符合编码规范(每个函数都要有注释, 方法变量的命名规则等...)
这些检查都很正常, 唯独一个比较辣手,那就是PD(一份Word文档).
PD中主要分两部分, 第一部分是UML图,
要求在UML图中,必须记载每一个变量名,函数名等等, 且必须与source完全一致.
这一点好办到, 只需要使用UML工具的逆向工程从source生成UML图即可.
PD中还需要的另一部分便是: 要为每一个类, 每一个变量, 每一个方法提供一个详细的说明(包括公有的和私有的一切)
以方法为例, 要求大概形如下面这样(类, 变量, 属性等类似):
这些关于方法,变量详细的记载, 同样要求与源代码一致(包括函数名, 参数, 函数注释等等)
在第一次做成这些文档和代码的时候还好些, 我们从一个地方拷贝到另一个地方, 他们初始是一致的,
然而接下来repeat的噩梦就开始了,两边同时维护, 总有漏下的,
而且需要花费很大的时间(尤其是检查),
有些时候, 日本方面的认真程度是我们中国人无法想象的,
比如从一份上百页的文档中, 他们能挑出某一个函数参数的大小写与source不一致这样的问题.
一个check不周,就有可能指摘.
关于问题, 已经介绍了差不多,
总之, 本着DRY原则,
同时也为了保证我们的这份word文档能够忠实于我们的source,
我想做的是: 从Source自动生成这份Word文档
为此要解决两个问题
1. 从Source中拿到相应的数据
2. 将相应的数据写到Word中.
对于第一个问题 ,
visual studio中, [右键一个项目 -> property -> Build -> Output]处有一个叫做[XML documentation file]的选项,
勾上他之后, 在build的时候, 就会同时生成一个xml文件, 这个文件中包含各个类的方法,成员变量, 以及他们的xml注释.
关于这个问题, 还可以参考下面两个项目, 他们帮助我们生成MSDN Style的帮助文档.
Sandcastle - Documentation Compiler for Managed Class Libraries
(我多么希望我们不需要维护这么一份word文件, 就使用上面的工具帮助我们生成MSDN Style的帮助文档就好....)
(然而总会有一些我们搞不定的人, 拥有一些和我们不同的喜好, 还好, 我们可以满足大家, 用程序生成这份文档吧....^-^)
对于第二个问题 ,也就是如何用程序生成这份word文档,
在网上搜了一下, 使用word画表格的例子比较少(表格多的操作都用excel去了)
于是结合网上搜索的结果, 我写了下面的demo程序,
能够生成前面贴图效果的word文档(实际上, 前面的那个图, 就是对下面程序的输出做的一个截屏)
下面的代码只有一个函数,
在入口处设置一个断点, 边执行边看word文件的效果, 想了解word automation的,应该可以了解一个大概.
在调查的过程中, 我发现下面的三个连接提供的示例代码比较有用, 贴到下面供大家参考(第一篇讲解的尤为详细).
Word automation using C# @C#Corner
Word automation using C# @social.msdn.microsoft.com
HOW TO:利用 Visual C# .NET 使 Word 自动新建文 档 @MSDN
How to automate Microsoft Word to perform Mail Merge from Visual C# @MSDN
Automating Word Tables for Data Insertion and Extraction @MSDN
如果你使用的是其他语言, 但也需要维护一份这样的word文档的话,
大都可以使用类似的方法解决,
比如如果是java, javadoc同样可以帮助我们生成xml文档(而不仅仅局限于大家熟知的html), 然后我们从这个xml文档转换成我们需要的格式.
过程中要用到JELDoclet , 详细做法参考这个链接Tip: Javadoc as XML @IBM DeveloperWorks
- class WordAuto
- {
- Word.Application wApp;
- Word._Document wDoc;
- Object oMissing = System.Reflection.Missing.Value;
- Object oFalse = false;
- public void CreateFile()
- {
- Word.Selection wSelection;
- Word.MailMerge wMailMerge;
- Word.MailMergeFields wMergeFields;
- Word.Table wTable;
- int rowsNum = 12;
- string StrToAdd;
- // Create an instance of Word and make it visible.
- wApp = new Word.Application();
- wApp.Visible = true;
- // Add a new document.
- wDoc = wApp.Documents.Add(ref oMissing, ref oMissing, ref oMissing, ref oMissing);
- wDoc.Select();
- wSelection = wApp.Selection;
- wSelection.ClearFormatting();
- wSelection.Paragraphs.OutlineLevel = Word.WdOutlineLevel.wdOutlineLevel2;
- wSelection.Font.Size = 20;
- wSelection.Font.ColorIndex = Word.WdColorIndex.wdBlack;
- wSelection.Font.Bold = 1;
- wSelection.TypeText("my first method");
- wApp.Selection.TypeParagraph();
- wSelection.Paragraphs.OutlineLevel = Word.WdOutlineLevel.wdOutlineLevelBodyText;
- wSelection.ClearFormatting();
- wSelection.Font.ColorIndex = Word.WdColorIndex.wdBlack;
- wSelection.TypeText("content of first......");
- wTable = wDoc.Tables.Add(wSelection.Range, rowsNum, 4, ref oMissing, ref oMissing);
- wTable.Rows[1].Cells.Shading.BackgroundPatternColorIndex = Word.WdColorIndex.wdGray25;
- //wTable.Columns[1].SetWidth(51, Word.WdRulerStyle.wdAdjustNone);
- wTable.Columns[1].SetWidth(70, Word.WdRulerStyle.wdAdjustProportional);
- wTable.Columns[3].SetWidth(70, Word.WdRulerStyle.wdAdjustProportional);
- wTable.Borders.Enable = 1;
- wTable.Rows[1].Cells[1].Merge(wTable.Rows[1].Cells[4]);
- wTable.Rows[1].Cells[1].Range.InsertAfter("MyNameSpace.MyClass#MyMethod() : MyRetureType");
- for (int i = 6; i <= rowsNum; i++)
- {
- wTable.Rows[i].Cells[2].Merge(wTable.Rows[i].Cells[4]);
- }
- wTable.Rows[6].Cells[1].Range.InsertAfter("详细定义");
- wTable.Rows[7].Cells[1].Range.InsertAfter("事前条件");
- wTable.Rows[8].Cells[1].Range.InsertAfter("事后条件");
- wTable.Rows[9].Cells[1].Range.InsertAfter("不变制约");
- wTable.Rows[10].Cells[1].Range.InsertAfter("非机能制约");
- wTable.Rows[11].Cells[1].Range.InsertAfter("备考");
- wTable.Rows[12].Cells[1].Range.InsertAfter("异常");
- wTable.Rows[2].Cells[1].Range.InsertAfter("函数输入");
- wTable.Rows[2].Cells[2].Range.InsertAfter("key::string");
- wTable.Rows[2].Cells[3].Range.InsertAfter("概要");
- wTable.Rows[2].Cells[4].Range.InsertAfter("my key to....");
- wTable.Rows[3].Cells[3].Range.InsertAfter("制约");
- wTable.Rows[3].Cells[4].Range.InsertAfter("key != null");
- wTable.Rows[4].Cells[1].Range.InsertAfter("函数输出");
- wTable.Rows[4].Cells[2].Range.InsertAfter("-");
- wTable.Rows[4].Cells[3].Range.InsertAfter("概要");
- wTable.Rows[5].Cells[3].Range.InsertAfter("制约");
- Cell startCell1 = wTable.Rows[2].Cells[1];
- Cell endCell1 = wTable.Rows[3].Cells[1];
- Cell startCell2 = wTable.Rows[2].Cells[2];
- Cell endCell2 = wTable.Rows[3].Cells[2];
- Cell startCell3 = wTable.Rows[4].Cells[1];
- Cell endCell3 = wTable.Rows[5].Cells[1];
- Cell startCell4 = wTable.Rows[4].Cells[2];
- Cell endCell4 = wTable.Rows[5].Cells[2];
- startCell1.Merge(endCell1);
- startCell2.Merge(endCell2);
- startCell3.Merge(endCell3);
- startCell4.Merge(endCell4);
- // Go to the end of the document.
- Object oConst1 = Word.WdGoToItem.wdGoToLine;
- Object oConst2 = Word.WdGoToDirection.wdGoToLast;
- wApp.Selection.GoTo(ref oConst1, ref oConst2, ref oMissing, ref oMissing);
- wSelection.InsertBreak();
- wSelection.Paragraphs.OutlineLevel = Word.WdOutlineLevel.wdOutlineLevel2;
- wSelection.Font.ColorIndex = Word.WdColorIndex.wdBlack;
- wSelection.Font.Size = 20;
- wSelection.Font.Bold = 1;
- wSelection.TypeText("my second method");
- wApp.Selection.TypeParagraph();
- wSelection.Paragraphs.OutlineLevel = Word.WdOutlineLevel.wdOutlineLevelBodyText;
- wSelection.ClearFormatting();
- wSelection.Font.ColorIndex = Word.WdColorIndex.wdBlack;
- wSelection.TypeText("content of second......");
- //another table
- wTable = wDoc.Tables.Add(wSelection.Range, rowsNum, 4, ref oMissing, ref oMissing);
- wTable.Borders.Enable = 1;
- ////............
- wDoc.SaveAs("c:\\word_auto.doc");
- wDoc.Close(false);
- wApp.Quit();
- wApp = null;
- }
- }
---end---
C# : 操作Word文件的API - (将C# source中的xml注释转换成word文档)的更多相关文章
- PDF文件可以转换成txt文档吗
PDF是一种便携式的文件格式,传送和阅读都非常方便,是Adobe公司开发的跨平台文件格式,它无论在哪种打印机上都可以保证精确的颜色和准确的打印效果.可是有点遗憾的是PDF格式一般不能在手机上打开,或者 ...
- ABBYY将JPEG文件转换成Word文档的方法
日常工作中处理JPEG格式的图像文件时,有时需要转换成Word文档进行编辑,市场上应用而生了很多转换工具,相信不少人听说过OCR(光学字符识别)软件,可以用来转换图像文件,而在OCR软件中, ABBY ...
- 如何使用ABBYY FineReader 12将JPEG文件转换成Word文档
日常工作中处理JPEG格式的图像文件时,有时需要转换成Word文档进行编辑,市场上应用而生了很多转换工具,相信不少人听说过OCR(光学字符识别)软件,可以用来转换图像文件,而在OCR软件中, ABBY ...
- ABBYY把pdf转换成word的方法
有时候我们在网上下载的资料文献是PDF格式文档,遇到喜欢的字句总忍不住想要收藏起来,但是PDF文档不同于普通的Word文档可以直接进行复制粘贴,需要下载安装相关的编辑工具,才能对文字内容进行编辑.倒不 ...
- pdf转换成word转换器免费版
在平时的办公中,我们只需要有一款比较好用的pdf转换成word转换器,就能提高我们的工作效率,但是国内外的pdf转换成word转换器应该怎么选呢?小编因为是文职工作者,所以在日常的实践中选出了ABBY ...
- HTML转换成word文档
1工具类保存word文件 public class WordAction { public static void SaveAsWord(string fileName, string pFileNa ...
- 将Latex tex文档转换成 word文档(下)
在上篇中我们介绍了一款将 tex 文件转换成 word 文件的工具 借用万能的搜索引擎,在 Google 上找到了更好的工具 它就是Pandoc 介绍 Pandoc 是由 John McaFarlan ...
- 将Latex tex文档转换成 word文档(上)
有时候逼不得已,必须得将自己精心排版好的latex 文档 转换成word 给别人编辑 以下提供一个方法 下载 Tex2Word 工具,地址我的网盘 安装 解压后安装,使用默认安装路径 安装过程中.点击 ...
- 用java将简单的word文档换成pdf文档
用java将简单的word文档换成pdf文档的方式很多,因为很多都没有实际测试过,所以这里就先泛泛的说一下 整体上来看分两种: 1.纯java代码实现,有很多优秀的开源软件可以用,比如poi,itex ...
随机推荐
- ASIHttpRequest编译不通过
转:http://blog.sina.com.cn/s/blog_67a5e47201014tof.html Undefined symbols for architecture i386: &q ...
- POJ 1401 Factorial
题意:求一个数的阶乘最后边有几个0. 解法:如果有0说明这个数含有2和5这两个因子,对于一个阶乘来说因子2的数量一定比5的数量多,所以只要算有几个5就可以了,依次算5的个数,25的个数,125的个数… ...
- HDU 5842 Lweb and String
Lweb and String Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)T ...
- oracle 统计语句 与常见函数的归纳(未完待续)
一.统计语句 1. count count(*)与count(0)语句的区别: count(*)统计所有数量 count(0)统计第一列不为空的 2. 两个统计量的减法 select (select ...
- HNU 13108-Just Another Knapsack Problem (ac自动机上的dp)
题意: 给你一个母串,多个模式串及其价值,求用模式串拼接成母串(不重叠不遗漏),能获得的最大价值. 分析: ac自动机中,在字典树上查找时,用dp,dp[i]拼成母串以i为结尾的子串,获得的最大价值, ...
- 《Python 学习手册4th》 第十二章 if测试和语法规则
''' 时间: 9月5日 - 9月30日 要求: 1. 书本内容总结归纳,整理在博客园笔记上传 2. 完成所有课后习题 注:“#” 后加的是备注内容 (每天看42页内容,可以保证月底看完此书) “重点 ...
- 使用jQuery Mobile实现通讯录
jQuery Mobile 通讯录 拨打电话作者:方倍工作室 地址: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional/ ...
- stl+模拟 CCF2016 4 路径解析
// stl+模拟 CCF2016 4 路径解析 // 一开始题意理解错了.... #include <iostream> #include <string> #include ...
- 解决PHP5.3.x下ffmpeg安装配置问题
本人的环境: OS : windows 7 64位 WAMP:2.1a PHP:5.3.3(之前是5.3.13) 项目需要用ffmpeg-php实现上传视频转码截图等功能,但是找了很多资料都没有把ff ...
- vs2010 无法连接到asp.net development server
http://blog.csdn.net/xqf309/article/details/7881257 今天打开之前的程序,按了F5进行调试,等了会弹出窗体来说:无法连接到asp.net develo ...