说明:

  程序使用 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. HDOJ 1864 最大报销额(01背包)

    http://acm.hdu.edu.cn/showproblem.php?pid=1864 最大报销额 Time Limit: 1000/1000 MS (Java/Others)    Memor ...

  2. cache写策略

    cache写策略 Write Through (完全写入) CPU向cache写入数据时,同时向memory也写一份,使cache和memory的数据保持一致.优点是简单,缺点是每次都要访问memor ...

  3. nginx gzip filter模块分析

    API:http://refspecs.linuxbase.org/LSB_3.1.1/LSB-Core-generic/LSB-Core-generic/zlib-deflateinit2.html ...

  4. 初尝easyui

    虽然以前做过很长时间的web,但是easyui却是从来没有用过,这次是花姑娘上花轿-头一遭.事情是这样的:前几天接手同事做的一个web项目,里面用到了部分easyui的控件,在属性的设置上有些缺失,故 ...

  5. 如何将一个div水平垂直居中?4种方法做推荐

    方案一: div绝对定位水平垂直居中[margin:auto实现绝对定位元素的居中], 兼容性:,IE7及之前版本不支持 div{ width: 200px; height: 200px; backg ...

  6. WEB实现单元格合并

    function merge_quadefect() { //可实现合并单元格,上下行来比较 //debugger; var totalCols = 7; 列数 var totalRows = $(& ...

  7. 什么是JDK?什么是JRE?JDK与JRE的区别和用途

    一.编程环境与运行环境 JDK(Java Development Kit)称为Java开发包或Java开发工具.是一个编写Java的Applet小程序和应用程序的程序开发环境.JDK是整个Java的核 ...

  8. Linux网络编程:基于TCP的程序开发回顾篇《转》

    面向连接的TCP程序设计 基于TCP的程序开发分为服务器端和客户端两部分,常见的核心步骤和流程: 其实按照上面这个流程调用系统API确实可以完全实现应用层程序的开发,一点问题没有.可随着时间的推移,你 ...

  9. Pycharm 2017.1 激活服务器

    最近发现pycharm激活异常困难 原来的激活码 都不能用了 so 根据网上 教程 自己建了激活服务器 尝试可用服务器 20170504 测试发现 给需要域名 http://www.05nb.com: ...

  10. 小程序在wxml页面中取整

    小程序无法像html中,在页面中直接parseInt() index.wxml {{price | Int}} 小程序还有另一种处理方法 wxs 是一种类似于js脚本的东西 filters.wxs v ...