说明:

  程序使用 io.h 中的 _findfirst 和 _findnext 函数遍历文件夹,故而程序只能在 Windows 下使用。  

  程序遍历当前文件夹,对其中的文件夹执行递归遍历。同时检查遍历到的文件是否属于指定类型,如果是,则将在该文件中查找指定字符串。 

  在文件中查找字符串时,开辟一个与指定字符串 text (长度为len )同样大小的字符串数组 temp 。数组上有两个指针:一个是字符串比较的开始位置 ,一个是新字符写入的位置 。每从文件中读入一个字符,就写入 temp[d] ,之后 temp 从 到 与 text 从  len-1 比较,之后, 与 均后移一位,再继续读入字符,写入,比较,后移。。。

代码:

 #include<stdio.h>
#include<vector>
#include<string.h>
#include<io.h>
using namespace std; vector<char*> types;
char text[]; void ls_path(char * path);
bool is_in_types(char* filename);
void findtext(char * filename,char* text); void solve(char* name,struct _finddata_t *f) {
if(strcmp(f->name,".")==)return ;
if(strcmp(f->name,"..")==)return ;
char *fullpath=new char[];
strcpy(fullpath,name);
int len=strlen(name);
fullpath[len-]='\0';
strcat(fullpath,f->name);
if(f->attrib&_A_SUBDIR) {
strcat(fullpath,"/*");
ls_path(fullpath);
} else {
if(is_in_types(f->name)) {
findtext(fullpath,text);
}
}
delete fullpath;
}
void ls_path(char * path) {
struct _finddata_t f;
int p;
char *name=new char[];
strcpy(name,path);
if((p=_findfirst(name, &f))!=-) {
solve(name,&f);
while(_findnext(p, &f)==) {
solve(name,&f);
}
}
delete name;
}
int strrncmp(char* a,const char* b,int n) {//比较两字符串的最后n个字符
int len=strlen(a);
int j=;
for(int i=len-n; i<=len-; i++) {
if(a[i]!=b[j])return false;
j++;
}
return j==n?true:false;
}
bool is_in_types(char* filename) {
for(int i=; i<types.size(); i++) {
if(strrncmp(filename,types[i],strlen(types[i]))) {
return true;
}
}
return false;
}
bool cmp(const char* temp,const int len,const int s,const int d,const char* text) {
int j=;
for(int i=s;; i++,i%=len) {
if(temp[i]!=text[j])return false;
if(i==d)break;
j++;
}
return true;
}
void findtext(char * filename,char* text) {
FILE *f=fopen(filename,"r");
char c;
int linenum=;
int len=strlen(text);
char* temp=new char[len];
int s=,d=len-;
while(c=fgetc(f),c!=EOF) {
temp[d]=c;
if(cmp(temp,len,s,d,text))printf("文件名: %s \n行号: %d\n",filename,linenum+);
if(c=='\n'||c=='\r'||c=='\r\n') {
linenum++;
}
d++;
d%=len;
s++;
s%=len;
}
delete temp;
fclose(f);
}
int main() {
printf("**************************************\n");
printf("本程序在其所在文件夹中查找指定类型文件\n中是否有指定字符串,并输出所在行号。\n");
printf(" CopyRight: maxuewei2\n");
printf("**************************************\n");
while(true) {
types.clear();
printf("\n请输入要查找的字符串:\n");
while(gets(text),strcmp(text,"")==);
printf("请输入文件类型,如‘txt’:(按两下ENTER开始查找)\n");
char t[];
while(gets(t),strcmp(t,"")!=) {
char* tt=new char[];
strcpy(tt,".");
strcat(tt,t);
types.push_back(tt);
}
delete t;
printf("查找结果:\n");
ls_path("*");
}
types.clear();
delete text;
getchar();
return ;
}

运行效果:

程序完成于2016.4.15

博客更新于2016.4.15

END

在文件夹中 的指定类型文件中 查找字符串(CodeBlocks+GCC编译,控制台程序,仅能在Windows上运行)的更多相关文章

  1. linux下删除3分钟之前指定文件夹下的指定类型文件

    如果想要修改crontab,一般做以下的几步就可以了 将crontab 推到一个自定义的文件上 crontab -l>;tmp 编辑这个文件,做需要的修改 vi tmp 推回crontab cr ...

  2. 怎样cp文件夹时忽略指定的文件夹和文件

    在备份ltedecoder程序时,须要把此文件夹拷由到bak文件夹下.但decoder文件夹下有个大文件,不须要备份,还有日志问题,也不须要备份,怎样实现呢?? 方法: cd /source-dir ...

  3. C#读取文件夹下所有指定类型,并返回相应类型数据

    C#读取文件夹下所有文件 本文提供全流程,中文翻译. Chinar 坚持将简单的生活方式,带给世人!(拥有更好的阅读体验 -- 高分辨率用户请根据需求调整网页缩放比例) Chinar -- 心分享.心 ...

  4. C#遍历文件夹下面所有指定格式文件

    C#遍历指定文件夹中的所有文件 DirectoryInfo TheFolder=new DirectoryInfo(folderFullName);//遍历文件夹foreach(DirectoryIn ...

  5. matlab操作之--读取指定文件夹下的“指定格式”文件

    %% 正负样本所在folder fext='*.png';%要读取的文件格式 positiveFolder='F:\课题\Crater detection\machingLearning\Positi ...

  6. Windows删除文件夹下的指定格式文件(递归删除)

    问题描述: 今天遇到一个需求,需要对文件夹进行文件筛选.目录结构较为复杂(目录较多,层次较深),数据量较大(总共60GB左右). 鉴于上述情况,直接排除了人工处理方式(否则小伙伴们会打死我的). 解决 ...

  7. iOS 获得指定文件夹下的指定格式文件

    这个容易忘记,然后只能用些自己写的长代码代替了....这里做个备忘 主要用到NSFileManager的 contentsOfDirectoryAtPath:error: 和 NSArray的 pat ...

  8. C#项目打开/保存文件夹/指定类型文件,获取路径

    C#项目打开/保存文件夹/指定类型文件,获取路径 转:http://q1q2q363.xiaoxiang.blog.163.com/blog/static/1106963682011722424325 ...

  9. [转]C#中调用资源管理器(Explorer.exe)打开指定文件夹 + 并选中指定文件 + 调用(系统默认的播放类)软件(如WMP)打开(播放歌曲等)文件

    原文:http://www.crifan.com/csharp_call_explorer_to_open_destinate_folder_and_select_specific_file/ C#中 ...

随机推荐

  1. log4Net(写入日志文件)

    这里就简单介绍下log4Net对写入日志文件的一些了解,写入数据库类似,就不在一一介绍了. 首先去log4net下载. 然后我们新建一个控制台应用程序,并引入log4net.dll程序集,log4ne ...

  2. Windows 10 下mysql 安装后无法启动问题

    安装过程: 1. 官网下载5.15.7, http://dev.mysql.com/downloads/, 选择开源社区版:MySQL Community Server (GPL) 2. 我解压后放在 ...

  3. css的三种样式

    1.行间样式 顾名思义就是直接写在div对里面的样式   2.内部样式 把样式写在一对<style></style>标签对中 这个标签对是放在html页面里面的   3.外联样 ...

  4. [moka同学笔记]五、Yii2.0课程笔记(魏曦老师教程)[审核功能]

  5. PHP流程控制之循环结构

    计算机程序最擅长的功能之一就是按规定的条件,重复执行某些操作.循环结构可以减少源程序重复书写的工作量,即在给定条件成立时,反复执行某程序段,直到条件不成立为止.给定的条件称为循环条件,反复执行的程序段 ...

  6. CSS3媒体查询使用小结

    首先我们在使用Media的时候需要先设置下面这段代码,来兼容移动设备的展示效果: 准备工作1:设置Meta标签 <meta name="viewport" content=& ...

  7. 深入浅出node(1) Node简介

    这一系列主要是自己在学习深入浅出node.js这本书的学习笔试,部分加入了自己的一些理解 分享给一起学习node的小伙伴 自己还是个初学者 有很多地方理解的不到位 一起交流 一 什么是node 1.1 ...

  8. Javascript对象

    这次的分享,主要还是想跟大家聊聊Javascript语言中很重要的概念之一,对象.为什么说之一呢?因为Javascript其他重要概念还包括:作用域 作用域链 继承 闭包 函数 继承 数组 ..... ...

  9. JS中用new创建对象与不用new创建对象区别:

    function classA() { console.log(this); var that = this == window ? {} : this; that.name = "clas ...

  10. Web API初探

    前几天有位同事说web api中的接口参数为对象的时候不好接收,具体什么方式我忘记了,虽然本人以前并没有接触过这方面的知识,但是据说和MVC差不多的,今天小小的研究一下,我想应该是可以的. 直接新建一 ...