zoukankan
html css js c++ java
类库说明文档生成器
原理很简单,解析程序集生成时的xml描述文档。设置生成程序集时生成xml描述文档的操作如下:
程序界面:
生成后的文档视图(样式调整需改源码)
关键代码:
/// <summary> /// 生成HTML说明文档 /// </summary> /// <param name="filePath">文件路径</param> public void GenneralHtmlDocument(string filePath) { XmlDocument doc = new XmlDocument(); doc.Load(filePath); XmlElement root = doc.DocumentElement; XmlNodeList nodeList = root.SelectNodes("members")[0].SelectNodes("member"); XmlNode assembly = root.SelectNodes("assembly")[0].SelectNodes("name")[0]; StringBuilder htmlBuilder = new StringBuilder(); htmlBuilder.Append(@"<!DOCTYPE HTML PUBLIC '-//W3C//DTD HTML 4.0 Transitional//EN'><html><head><title></title></head><body>"); htmlBuilder.Append("<table>"); foreach (XmlNode item in nodeList) { string name = item.Attributes["name"].InnerText; if (name.StartsWith("T"))//类标识 { string className = name.Substring(name.LastIndexOf(".") + 1); htmlBuilder.Append(string.Format(@" <tr><td colspan='6'> <b>【命名空间:{0}】</b></td></tr>", assembly.InnerText.TrimSpace())); htmlBuilder.Append(string.Format(@" <tr><td colspan='6'> <b>类名:{0}</b></td></tr>", className)); } else if (name.StartsWith("M"))//方法标识 { string parmsTypeString = string.Empty; string[] parmsTypeArr = new string[] { }; if (name.Contains("(") & name.Contains(")")) { parmsTypeString = name.Substring(name.IndexOf("(") + 1, name.LastIndexOf(")") - (name.IndexOf("(") + 1)); parmsTypeArr = parmsTypeString.Split(new string[] { "," }, StringSplitOptions.RemoveEmptyEntries); } name = name.Contains("(") ? name.Substring(0, name.LastIndexOf("(")) : name; string methodName = name.Substring(name.LastIndexOf(".") + 1); string methodDescription = item.SelectNodes("summary")[0].InnerText.TrimSpace(); htmlBuilder.Append(string.Format(@"<tr><td class='tdleft'>方法名</td><td>{0}</td><td class='tdleft'>方法描述</td><td colspan='2'>{1}</td></tr>", methodName, methodDescription)); htmlBuilder.Append("<tr> <td class='tdleft'>参数名称 </td> <td class='tdleft'> 参数类型 </td> <td class='tdleft'> 是否必须 </td><td class='tdleft'>参数描述</td><td class='tdleft'>默认值</td> </tr>"); XmlNodeList parmsList = item.SelectNodes("param"); for (int i = 0; i < parmsList.Count; i++) { string parmsName = parmsList[i].Attributes["name"].InnerText.TrimSpace(); string parmsType = i < parmsTypeArr.Length ? parmsTypeArr[i].TrimSpace() : ""; string parmsNotes = parmsList[i].InnerText.TrimSpace(); string parmsIsNull = "Null"; string parmsDefaultValue = GetTypeDefaultValue(parmsType); htmlBuilder.Append(string.Format("<tr><td>{0}</td><td>{1}</td><td>{2}</td><td>{3}</td><td>{4}</td></tr>", parmsName, parmsType, parmsIsNull, parmsNotes, parmsDefaultValue)); } if (item.SelectNodes("returns").Count > 0) { string retrun = item.SelectNodes("returns")[0].InnerText.TrimSpace(); htmlBuilder.Append(string.Format("<tr><td class='tdleft'>返回结果:</td><td colspan='5'>{0}</td></tr>", retrun)); } htmlBuilder.Append("<tr><td colspan='6'></td></tr>"); } } htmlBuilder = new StringBuilder(htmlBuilder.ToString().Substring(0, htmlBuilder.ToString().Length - "<tr><td colspan='6'></td></tr>".Length)); htmlBuilder.Append("</table>"); htmlBuilder.Append("<style type='text/css'>"); htmlBuilder.Append(".tdleft{ background-color: #F2F5A9;10%;}"); htmlBuilder.Append(".tdvalue{ 200px;}"); //表格加边框样式 htmlBuilder.Append(@"table{border-collapse:collapse;border-spacing:0;border-left:1px solid #888;border-top:1px solid #888;background:#efefef;}th,td{border-right:1px solid #888;border-bottom:1px solid #888;padding:5px 15px;}th{font-weight:bold;background:#ccc;}"); htmlBuilder.Append("</style>"); htmlBuilder.Append(@"</body></html>"); string documentFilePath = Environment.CurrentDirectory + Path.DirectorySeparatorChar + "document.htm"; SaveStringToFile(documentFilePath, htmlBuilder.ToString()); ShowFile(documentFilePath); }
源码下载:
下载地址
查看全文
相关阅读:
PowerDesigner
人工智能
Tomcat已经配置好了,但是访问localhost:8080出错
SQL重复记录查询-count与group by having结合查询重复记录
SQL SERVER下图片的插入与读取(转)
plsql中文乱码问题(显示问号)转
2018福大软工实践第二次作业
2018福大软工实践第一次作业
2018福大软工实践第一次作业-自我介绍
2017《面向对象程序设计》课程作业八
原文地址:https://www.cnblogs.com/zhangqs008/p/2498391.html
最新文章
[数据库事务与锁]详解五: MySQL中的行级锁,表级锁,页级锁
[数据库事务与锁]详解六: MySQL中的共享锁与排他锁
[数据库事务与锁]详解七: 深入理解乐观锁与悲观锁
[数据库事务与锁]详解八:底理解数据库事务乐观锁的一种实现方式——CAS
javaweb学习总结—Apache的DBUtils框架学习
[JavaWeb]关于DBUtils中QueryRunner的一些解读.
代码简洁之道之我见
C# 消息队列RabbitMQ的简单使用
C# 简单操作缓存数据库Redis
对计算思维的一些认识
热门文章
JSON序列化框架 【Newtonsoft.Json】 的使用
基础算法——递归与递推
轻量级ORM框架 【Dapper】 的使用
C# 多线程的创建
控制反转容器 【Autofac】 的使用
实体属性映射框架 【AutoMapper】 的使用
Oracle中的字符串类型及相关函数详解
命令行net time同步时间(内网)
oracle存储过程的基本语法
excel中补全8位工号
Copyright © 2011-2022 走看看