前几天,领导让我找一下老系统(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文件里查询方法使用次数工具的更多相关文章

  1. .wsdl文件生成.cs文件

    1.打开VS文件命令行工具(一般在安装文件的Common7\Tools\Shortcuts下面例如[E:\VS2013安装程序\Common7\Tools\Shortcuts\VS2013 x64 本 ...

  2. .resx文件与.cs文件的自动匹配

    图中myCommands.Resx是<DependentUpon> myCommands.cs文件的. 如何为其他的.cs文件添加类似的资源文件呢? 其实挺简单, 添加与.cs文件同名的资 ...

  3. protoc文件生成cs文件

    1.下载protoc工具  点击下载 2.下载解压后打开文件,其中有一个.bat文件,里面对应命令行如下: 编写如下命令行 protoc.exe -I=. --csharp_out=. --grpc_ ...

  4. xsd文件生成cs文件命令

    C:\Windows\System32>xsd.exe c:/Createst.xsd -c C:\Windows\System32>xsd.exe c:/Creauest.xsd /c ...

  5. 如何将编写好的CS文件做成exe可执行文件

    编译好的控制台CS文件: cs文件单独拿出来放到F盘目录中 打开命令提示CMD: 执行下面语句即可在F盘目录中看到生成的exe文件,windows系统下双击就可运行: C:\Windows\Micro ...

  6. C# 在类文件自动添加文件注释的方法

    对于vs2013来讲, 步骤: 1.VS2013 中找到(安装盘符以C盘为例)C:\ProgramFiles(x86)\Microsoft VisualStudio12.0\Common7\IDE\I ...

  7. 利用java反射调用类的的私有方法--转

    原文:http://blog.csdn.net/woshinia/article/details/11766567 1,今天和一位朋友谈到父类私有方法的调用问题,本来以为利用反射很轻松就可以实现,因为 ...

  8. jar包里查找指定的class文件,排查是否存在或重复,工具软件:Java Class Finder

    jar包里查找指定的class文件,排查是否存在或重复,工具软件:Java Class Finder 1,下载工具地址:www.idesksoft.com/classfinder.html,如图: 2 ...

  9. java 查询路径中所有文件夹和文件的名称,支持文件名模糊查询

    java 查询路径中所有文件夹和文件的名称,支持文件名模糊查询 有时候我们遇到需要查询服务器或者本机某个路径下有哪些文件?或者根据文件名称模糊搜索文件,那么就可以使用本方法:可以获取某个路径下所有文件 ...

随机推荐

  1. 01.SQLServer性能优化之----强大的文件组----分盘存储

    汇总篇:http://www.cnblogs.com/dunitian/p/4822808.html#tsql 文章内容皆自己的理解,如有不足之处欢迎指正~谢谢 前天有学弟问逆天:“逆天,有没有一种方 ...

  2. Storm如何保证可靠的消息处理

    作者:Jack47 PS:如果喜欢我写的文章,欢迎关注我的微信公众账号程序员杰克,两边的文章会同步,也可以添加我的RSS订阅源. 本文主要翻译自Storm官方文档Guaranteeing messag ...

  3. MIP 官方发布 v1稳定版本

    近期,MIP官方发布了MIP系列文件的全新v1版本,我们建议大家尽快完成升级. 一. 我是开发者,如何升级版本? 对于MIP页面开发者来说,只需替换线上引用的MIP文件为v1版本,就可以完成升级.所有 ...

  4. 【翻译】MongoDB指南/CRUD操作(三)

    [原文地址]https://docs.mongodb.com/manual/ CRUD操作(三) 主要内容: 原子性和事务(Atomicity and Transactions),读隔离.一致性和新近 ...

  5. ASP.NET MVC5+EF6+EasyUI 后台管理系统(73)-微信公众平台开发-消息管理

    系列目录 前言 回顾上一节,我们熟悉的了解了消息的请求和响应,这一节我们来建立数据库的表,表的设计蛮复杂 你也可以按自己所分析的情形结构来建表 必须非常熟悉表的结果才能运用这张表,这表表的情形涵盖比较 ...

  6. SQL Server-聚焦计算列或计算列持久化查询性能(二十二)

    前言 上一节我们详细讲解了计算列以及计算列持久化的问题,本节我们依然如前面讲解来看看二者查询性能问题,简短的内容,深入的理解,Always to review the basics. 持久化计算列比非 ...

  7. ASP.NET加密和解密数据库连接字符串

    大家知道,在应用程序中进行数据库操作需要连接字符串,而如果没有连接字符串,我们就无法在应用程序中完成检索数据,创建数据等一系列的数据库操作.当有人想要获取你程序中的数据库信息,他首先看到的可能会是We ...

  8. JS继承类相关试题

    题目一: //有关于原型继承的代码如下:function Person(name) {   this.name = name;}Person.prototype = {     getName : f ...

  9. C# 用SoapUI调试WCF服务接口(WCF中包含用户名密码的验证)

    问题描述: 一般调试wcf程序可以直接建一个单元测试,直接调接口. 但是,这次,我还要测试在接口内的代码中看接收到的用户名密码是否正确,所以,单一的直接调用接口方法行不通, 然后就想办法通过soapU ...

  10. Block解析(iOS)

    1. 操作系统中的栈和堆 我们先来看看一个由C/C++/OBJC编译的程序占用内存分布的结构: 栈区(stack):由系统自动分配,一般存放函数参数值.局部变量的值等.由编译器自动创建与释放.其操作方 ...