第一次写博客有点激动啊QAQ

  来新单位,一直没活干,公司代码控制器太多,其中有很多文件夹,每次找一个控制器都老找不到,我又不愿意用VS的全局搜索,想着没事就做了个查找控制器的小工具。代码如下:

先添加了界面

在pagelode里首先需要构建一张虚拟表

private void Form1_Load(object sender, EventArgs e)

{

DataColumn d1 = new DataColumn("ID", typeof(int));

DataColumn d2 = new DataColumn("Name", typeof(string));

DataColumn d3 = new DataColumn("PID", typeof(string));

dt.Columns.Add(d1);

dt.Columns.Add(d2);

dt.Columns.Add(d3);

}

之后再创建确定按钮的代码,确定是说查找路径。。

private void button2_Click(object sender, EventArgs e)

{

if (treeView1.Nodes.Count != 0)

treeView1.Nodes.Clear();

string path = txtSeachFolder.Text;

try

{

//if (path != "")

if(path.Trim()=="")

{

path = @"D:\Project\SourceCode\CFLD.PMS_v2.0\CFLD.PMS.Web\Controllers";

FindFile(path);

}

else if (path != "")

{

FindFile(path);

}

else

MessageBox.Show("请输入路径");

}

catch (Exception ex)

{

MessageBox.Show(ex.Message);

}

}

这里面的findfile是用来填充树控件的,具体代码是

public void FindFile(string dirPath)

{

DataRow[] rows = dt.Select("ID=-1");

DirectoryInfo di=new DirectoryInfo(dirPath);

var folder = di.GetDirectories();

List<string> conNames = new List<string>();

if (folder.Count() != 0)

{

#region 文件夹

try

{

int i = 0;

foreach (var item in folder)

{

TreeNode tn = new TreeNode();

DataRow dr = dt.NewRow();

dr["ID"] = i;

dr["Name"] = item.Name;

dr["PID"] = i;

dt.Rows.Add(dr);

tn.Tag = dr;

tn.Text = item.Name;

foreach (var item1 in item.GetFiles())

{

TreeNode tn1 = new TreeNode();

tn1.Text = item1.Name;

tn.Nodes.Add(tn1);

}

treeView1.Nodes.Add(tn);

listBox1.Items.Add(item.Name);

i++;

}

}

catch (Exception ex)

{

MessageBox.Show(ex.Message);

}

#endregion

}

else

{

try

{

int j = 0;

var files = di.GetFiles();

foreach(var item in files)

{

TreeNode tn = new TreeNode();

DataRow dr = dt.NewRow();

dr["ID"] = j;

dr["Name"] = item.Name;

dr["PID"] = j;

dt.Rows.Add(dr);

tn.Tag = dr;

tn.Text = item.Name;

treeView1.Nodes.Add(tn);

listBox1.Items.Add(item.Name);

j++;

}

}

catch (Exception ex)

{

MessageBox.Show(ex.Message);

}

}

}

在之后是查找的代码

private void button1_Click(object sender, EventArgs e)

{

bool b = false;

string value = txtSearch.Text;

this.treeView1.CollapseAll();

foreach (TreeNode node in this.treeView1.Nodes)

{

b= nextnodes(node, value);

if (b)

break;

}

if (!b)

MessageBox.Show("没有查到");

}

这里面的nextnode是用来确定查找到的节点位置的,具体代码是

public bool nextnodes(TreeNode node, string text)

{

foreach (TreeNode tn in node.Nodes)

{

if(tn.Text.ToUpper().Contains(text.ToUpper().Trim()))

{

tn.BackColor = Color.Green; //改变查找到的节点背景色;

if (tn.Parent != null)

tn.Parent.Expand(); //展开服节点

return true;

}

}

return false;

},

好了,看下效果

c#做的查找文件夹内内容的小工具的更多相关文章

  1. Ubuntu 查找文件夹中内容包含关键字的文件,路径为当前文件夹

    From CSDN http://blog.csdn.net/lizhenmingdirk/article/details/44834997 grep -rl "keyword" ...

  2. Linux批量替换文本,文件夹内所有文本内容

    1.替换文件夹内所有文件匹配的字符串 sed -i "s/旧内容/新内容/g" `grep 旧内容 -rl 文件夹路径` 例如将/var/www/test文件夹下的所有文件内容中的 ...

  3. 编写Java程序,在一个文件夹内,查找占用磁盘空间最大的 jpg 文件,并输出文件大小

    查看本章节 查看作业目录 需求说明: 在一个文件夹内,查找占用磁盘空间最大的 jpg 文件,并输出文件大小 实现思路: 创建ImageFileFilter类实现FilenameFilter接口,且重写 ...

  4. shell脚本实现查找文件夹下重复的文件,并提供删除功能

    Windows下有软件FindDupFile,可以搜索指定目录及其下子目录,列出所有内容完全相同的文件(文件名可能不同),然后由用户选择删除重复的文件. 然而shell脚本却可以使用几行的命令完成与此 ...

  5. ftp下载目录下所有文件及文件夹内(递归)

    ftp下载目录下所有文件及文件夹内(递归)   /// <summary> /// ftp文件上传.下载操作类 /// </summary> public class FTPH ...

  6. 批量生成文件夹内所有文件md5

    说明:md5批量生成批处理脚本,无需安装任何软件,直接调用系统文件进行生成,简单基于windows命令编写了一个批量生成md5值的脚本. 使用说明:新建文本文档,命名为get_md5.bat,直接将代 ...

  7. apache环境下禁止某文件夹内运行PHP脚本、禁止访问文件或目录执行权限的设置方法

    apache环境下禁止某文件夹内运行PHP脚本.禁止访问文件或目录执行权限的设置方法   首先我们来看两段对上传目录设置无权限的列子,配置如下: <Directory "要去掉PHP执 ...

  8. linux查找文件夹下的全部文件里是否含有某个字符串

    查找文件夹下的全部文件里是否含有某个字符串  find .|xargs grep -ri "IBM"  查找文件夹下的全部文件里是否含有某个字符串,而且仅仅打印出文件名称  fin ...

  9. ls命名 | Linux统计文件夹内的文件个数

    ls命名 man ls -R 递归列出全部的目录内容 recusive -a 列出所有的文件(包括以 . 开头的隐藏文件) all -r 逆序排列 reverse -t 按照时间信息排序 time - ...

随机推荐

  1. Ubuntu 安装后的配置及美化(一)

    Ubuntu 安装后的配置及美化(一) 记录一下 完成后的主界面. 配置 1.更新源为阿里云 找到 软件和更新 选项,更新源为阿里云的源. 在 其他软件 中将 Canonical合作伙伴 打上勾. 然 ...

  2. 洛谷P2754 [CTSC1999]家园(最大流)

    传送门 这题思路太强了……大佬们怎么想到的……我这菜鸡根本想不出来…… 先判断是否能到达,对每一艘飞船能到的地方用并查集合并一下,最后判断一下是否连通 然后考虑几天怎么判断,我们可以枚举. 每一个点表 ...

  3. DRF中的版本控制

    一.为什么要有版本 某些客户端 使用低版本只维护不开发新功能 v1 主要的产品还要不断的更新迭代功能 v2 API 版本控制允许我们在不同的客户端之间更改行为(同一个接口的不同版本会返回不同的数据). ...

  4. socket长连接 GCDAsyncSocket

    基础: http://www.2cto.com/kf/201609/546974.html 转自: http://blog.csdn.net/u013282507/article/details/52 ...

  5. JavaWeb学习笔记(十)—— JavaBean总结【转】

    一.什么是JavaBean JavaBean是一个遵循特定写法的Java类,它通常具有如下特点: 这个Java类必须具有一个无参的构造函数 属性必须私有化. 私有化的属性必须通过public类型的方法 ...

  6. Windows10 下安装配置IIS + MySQL5.7.19 + nginx1.12.1 + php7.1.7

    环境: VMWare Workstation Player12 Windows10 Pro x64 一.安装系统 vmware 会采用 fast install 方式很快装完,无需配置什么. 二.配置 ...

  7. Tensorflow基础-mnist数据集

    MNIST数据集,每张图片包含28*28个像素,把一个数组展开成向量,长度为28*28=784,故数据集中mnist.train.images是一个形状为[60000,784]的张量,第一个维度数字用 ...

  8. ElementUI 时间控件

    <template> <div class="block"> <span class="demonstration">默认& ...

  9. hibernateUtil类

    package com.test.Util; import org.hibernate.SessionFactory; import org.hibernate.cfg.AnnotationConfi ...

  10. 剑指offer5.1——O(n)的复杂度合并两个有序数组

    #include"iostream" #include"stdio.h" using namespace std; int* ArrayMerge(int *a ...