从java文件和CS文件里查询方法使用次数工具
前几天,领导让我找一下老系统(Java)里getRemoteUser方法都哪个文件用了,package是什么,方法被调用了多少次,当时因为着急,所以,直接人工找的,但是以后要是再出现,人工找就太讨厌了,毕竟程序员以懒著称,因此,写了一个小工具进行查询。
一、效果图


从图中不难看出,现在的功能只能查询两类文件java和cs,毕竟是针对我们用的,如果想扩展的话,也是没有问题的,毕竟方法是通用的。
最终得到的是一个excel


二、开发过程
1、首先建一个实体类
实体类里面包含包名、文件名和使用次数
class ContentEntity
{
private string _paOrns;
private string _fileName;
private int useCount;
/// <summary>
/// package或者是NameSpace
/// </summary>
public string PaOrns
{
get
{
return _paOrns;
} set
{
_paOrns = value;
}
}
/// <summary>
/// 文件名
/// </summary>
public string FileName
{
get
{
return _fileName;
} set
{
_fileName = value;
}
}
/// <summary>
/// 使用次数
/// </summary>
public int UseCount
{
get
{
return useCount;
} set
{
useCount = value;
}
}
}
实体类
2、截取字段
因为要从Java文件里取出package后面的内容,CS文件里取出NameSpace后面的内容,因此需要用到截取字段,这个小工具的开发并没有用SubString来截取字段,而是用的正则表达式
class Match
{
/// <summary>
/// 获取java的package
/// </summary>
/// <param name="str"></param>
/// <returns></returns>
public static string GetPackage(string str)
{
return Regex.Match(str, "(?<=package).*?(?=;)").Value;
}
/// <summary>
/// 获取C#的NameSpace
/// </summary>
/// <param name="str"></param>
/// <returns></returns>
public static string GetNamespace(string str)
{
return Regex.Match(str, "(?<=namespace).*?(?=\r)").Value;
}
/// <summary>
/// 获取文件名
/// </summary>
/// <param name="str"></param>
/// <returns></returns>
public static string GetFileName(string str)
{
return Regex.Match(str, "(?<=_).*?(?=_)").Value;
}
/// <summary>
/// 获取命名空间
/// </summary>
/// <param name="str"></param>
/// <returns></returns>
public static string GetPaOrNs(string str)
{
return Regex.Match(str, "^.*?(?=_)").Value;
}
}
正则截取字段
3、读取文件夹下文件
循环遍历选择的文件夹路径下的所有文件
/// <summary>
/// 取得指定路径下所有目录及文件名称(可递归)
/// </summary>
/// <param name="strDir">指定路径</param>
/// <param name="strFilePattern">要与 strDir 中的文件名匹配的搜索字符串
/// “*.abc*”返回扩展名为 .abc、.abcd、.abcde、.abcdef 等的文件。
/// “*.abcd”只返回扩展名为 .abcd 的文件。
/// “*.abcde”只返回扩展名为 .abcde 的文件。
/// </param>
/// <param name="arrDirs">查询得到的所有目录</param>
/// <param name="arrFiles">查询得到的所有文件名称</param>
/// <param name="bIsRecursive">是否递归查询</param>
/// <returns></returns>
private static List<string> GetFileList(string strDir, string strFilePattern, List<string> arrDirs, List<string> arrFiles, bool bIsRecursive)
{
DirectoryInfo dirInfo = new DirectoryInfo(strDir);
if (string.IsNullOrEmpty(strDir))
return null; try
{
//取得指定路径下的所有符合条件的文件
FileInfo[] strFiles = dirInfo.GetFiles(strFilePattern);
//取得指定路径下的所有目录
DirectoryInfo[] strDirs = dirInfo.GetDirectories(); foreach (FileInfo item in strFiles)
{//将所有文件名称加入arrFiles中
arrFiles.Add(item.FullName);
} foreach (DirectoryInfo item in strDirs)
{//将所有目录名称加入arrDirs中
arrDirs.Add(item.FullName);
} if (bIsRecursive)
{//递归
if (strDirs.Length > )
{
foreach (DirectoryInfo item in strDirs)
{//递归遍历所有文件夹
GetFileList(item.FullName, strFilePattern, arrDirs, arrFiles, bIsRecursive);
}
}
}
}
catch (Exception)
{
throw;
}
return arrFiles;
}
读取文件夹下的文件
4、读取需要的文件
读取java或cs文件,并判断里面是否存在要搜索的关键字
/// <summary>
/// 获取包含查询内容的集合
/// </summary>
/// <param name="path">路径</param>
/// <param name="searchStr">要查询的内容</param>
public static List<ContentEntity> GetInfoIncludeSearchStr(string path, string searchStr, string type)
{
List<ContentEntity> ceList = new List<ContentEntity>();
ContentEntity ce; //获取查询内容的长度
int strLength = searchStr.Length;
//包含路径的所有集合
List<string> AllFile = GetFileList(path, type, new List<string>(), new List<string>(), true);
foreach (string item in AllFile)
{
FileStream fs = new FileStream(item, FileMode.Open, FileAccess.Read, FileShare.None);
StreamReader sr = new StreamReader(fs);
//读取文件的内容
string strLine = sr.ReadToEnd();
if (strLine.Length >= strLength)
{
for (int i = ; i < strLine.Length - strLength; i++)
{
//判断是否包含查询的内容
if (strLine.Substring(i, strLength).Equals(searchStr))
{
ce = new ContentEntity()
{
PaOrns = type == FileType.type_Java ? Match.GetPackage(strLine) : Match.GetNamespace(strLine),//判断是哪种类型,选择不同的处理方式
FileName = Path.GetFileName(item),
UseCount =
};
ceList.Add(ce);
}
}
}
//关闭
sr.Close();
fs.Close();
}
return ceList;
}
查询关键字
5、导出到excel
将最终得到的结果导出到excel,并打开excel
public static void ExportExcel(System.Data.DataTable dt)
{
if (dt == null || dt.Rows.Count == )
return;
Application xlApp = new Application();
if (xlApp == null)
return;
CultureInfo CurrentCI = Thread.CurrentThread.CurrentCulture;
Thread.CurrentThread.CurrentCulture = new CultureInfo("en-US");
Workbooks workbooks = xlApp.Workbooks;
Workbook workbook = workbooks.Add(XlWBATemplate.xlWBATWorksheet);
Worksheet worksheet = workbook.Worksheets[];
Range range;
long totalCount = dt.Rows.Count;
long rowRead = ;
long percent = ;
for (int i = ; i < dt.Columns.Count; i++)
{
worksheet.Cells[, i + ] = dt.Columns[i].ColumnName;
range = worksheet.Cells[, i + ];
range.Interior.ColorIndex = ;
}
for (int i = ; i < dt.Rows.Count; i++)
{
for (int j = ; j < dt.Columns.Count; j++)
{
try
{
worksheet.Cells[i + , j + ] = dt.Rows[i][j].ToString();
}
catch
{
worksheet.Cells[i + , j + ] = dt.Rows[i][j].ToString().Replace("=", "");
}
}
rowRead++;
percent = ( * rowRead) / totalCount;
}
worksheet.Columns.EntireColumn.AutoFit();//列宽自适应
worksheet.Shapes.AddTextEffect(MsoPresetTextEffect.msoTextEffect1, " ", "Red", , MsoTriState.msoFalse, MsoTriState.msoTrue, , );
xlApp.Visible = true;
}
导出excel
从java文件和CS文件里查询方法使用次数工具的更多相关文章
- .wsdl文件生成.cs文件
1.打开VS文件命令行工具(一般在安装文件的Common7\Tools\Shortcuts下面例如[E:\VS2013安装程序\Common7\Tools\Shortcuts\VS2013 x64 本 ...
- .resx文件与.cs文件的自动匹配
图中myCommands.Resx是<DependentUpon> myCommands.cs文件的. 如何为其他的.cs文件添加类似的资源文件呢? 其实挺简单, 添加与.cs文件同名的资 ...
- protoc文件生成cs文件
1.下载protoc工具 点击下载 2.下载解压后打开文件,其中有一个.bat文件,里面对应命令行如下: 编写如下命令行 protoc.exe -I=. --csharp_out=. --grpc_ ...
- xsd文件生成cs文件命令
C:\Windows\System32>xsd.exe c:/Createst.xsd -c C:\Windows\System32>xsd.exe c:/Creauest.xsd /c ...
- 如何将编写好的CS文件做成exe可执行文件
编译好的控制台CS文件: cs文件单独拿出来放到F盘目录中 打开命令提示CMD: 执行下面语句即可在F盘目录中看到生成的exe文件,windows系统下双击就可运行: C:\Windows\Micro ...
- C# 在类文件自动添加文件注释的方法
对于vs2013来讲, 步骤: 1.VS2013 中找到(安装盘符以C盘为例)C:\ProgramFiles(x86)\Microsoft VisualStudio12.0\Common7\IDE\I ...
- 利用java反射调用类的的私有方法--转
原文:http://blog.csdn.net/woshinia/article/details/11766567 1,今天和一位朋友谈到父类私有方法的调用问题,本来以为利用反射很轻松就可以实现,因为 ...
- jar包里查找指定的class文件,排查是否存在或重复,工具软件:Java Class Finder
jar包里查找指定的class文件,排查是否存在或重复,工具软件:Java Class Finder 1,下载工具地址:www.idesksoft.com/classfinder.html,如图: 2 ...
- java 查询路径中所有文件夹和文件的名称,支持文件名模糊查询
java 查询路径中所有文件夹和文件的名称,支持文件名模糊查询 有时候我们遇到需要查询服务器或者本机某个路径下有哪些文件?或者根据文件名称模糊搜索文件,那么就可以使用本方法:可以获取某个路径下所有文件 ...
随机推荐
- LINUX篇,设置MYSQL远程访问实用版
每次设置root和远程访问都容易出现问题, 总结了个通用方法, 关键在于实用 step1: # mysql -u root mysql mysql> Grant all privileges o ...
- 【探索】机器指令翻译成 JavaScript
前言 前些时候研究脚本混淆时,打算先学一些「程序流程」相关的概念.为了不因太枯燥而放弃,决定想一个有趣的案例,可以边探索边学. 于是想了一个话题:尝试将机器指令 1:1 翻译 成 JavaScript ...
- 对抗假人 —— 前后端结合的 WAF
前言 之前介绍了一些前后端结合的中间人攻击方案.由于 Web 程序的特殊性,前端脚本的参与能大幅弥补后端的不足,从而达到传统难以实现的效果. 攻防本为一体,既然能用于攻击,类似的思路同样也可用于防御. ...
- TODO:Laravel 使用blade标签布局页面
TODO:Laravel 使用blade标签布局页面 本文主要介绍Laravel的标签使用,统一布局页面.主要用到到标签有@yield,@ stack,@extends,@section,@stop, ...
- KV存储系统
现在的KV存储系统都是分布式的,首先介绍Zookeeper——针对大型分布式系统的高可靠的协调系统. 开发分布式系统是件很困难的事情,其中的困难主要体现在分布式系统的“部分失败”.“部分失败”是指信息 ...
- 为.NET Core项目定义Item Template
作为这个星球上最强大的IDE,Visual Studio不仅仅提供了很多原生的特性,更重要的是它是一个可定制的IDE,比如自定义Project Template和Item Template就是一个非常 ...
- 学习笔记之MVC级联及Ajax操作
由于刚转型到MVC,MVC的架构模式很多不是很清楚,比如今天就想做个级联的操作,因为之前的ASP.NET的方式是通过:控件-->添加事件-->后台编写级联事件进行触发,但是这个MVC就不同 ...
- Android 工具-adb
Android 工具-adb 版权声明:本文为博主原创文章,未经博主允许不得转载. Android 开发中, adb 是开发者经常使用的工具,是 Android 开发者必须掌握的. Android D ...
- C#通过NPOI操作Excel
参考页面: http://www.yuanjiaocheng.net/webapi/create-crud-api-1-post.html http://www.yuanjiaocheng.net/w ...
- EF上下文对象线程内唯一性与优化
在一次请求中,即一个线程内,若是用到EF数据上下文对象,就创建一个,这也加是很多人的代码中习惯在使用上下文对象时,习惯将对象建立在using中,也是为了尽早释放上下文对象, 但是如果有一个业务逻辑调用 ...