热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

C++读取一个目录下的所有txt文件

C++读取一个目录下的所有txt文件,并显示哪个txt文件里的哪个数最大(这些txt里是多行数字,偶尔有非数字)各位大神帮帮忙啊,有代码最好啊,没有代码有方法也很满意了!!@-@
C++读取一个目录下的所有txt文件,并显示哪个txt文件里的哪个数最大(这些txt里是多行数字,偶尔有非数字)
各位大神帮帮忙啊,有代码最好啊,没有代码有方法也很满意了!!@-@

16 个解决方案

#1


findfirst
findnext

#2


能说下具体的语句吗,还有把txt读出来后怎么显示其最大值,谢谢

#3


引用 2 楼 CSDN______ 的回复:
能说下具体的语句吗,还有把txt读出来后怎么显示其最大值,谢谢



#include 
#include 
#include 
using namespace std;

int main() {
_finddata_t sFind;
long lResult;

while(lResult != -1) {
cout << sFind.name << endl;
cout << sFind.size << endl;
_findnext(lResult, &sFind);
}

// 文件内容读取,得看内内容是什么样的了。
return 0;
}

#4


能说下具体的语句吗,还有把txt读出来后怎么显示其最大值,谢谢

引用 3 楼 zjq9931 的回复:
Quote: 引用 2 楼 CSDN______ 的回复:

能说下具体的语句吗,还有把txt读出来后怎么显示其最大值,谢谢



#include 
#include 
#include 
using namespace std;

int main() {
_finddata_t sFind;
long lResult;

while(lResult != -1) {
cout << sFind.name << endl;
cout << sFind.size << endl;
_findnext(lResult, &sFind);
}

// 文件内容读取,得看内内容是什么样的了。
return 0;
}






我编译结果是这样的,文件里是几个txt,txt里是多行数字,比如
1 2 3
4 5 6
7 8 9
这样的,txt求最大值我会,就是把程序串不起来

#5



#include 
#include 
#include 
using namespace std;

int main() {
_finddata_t sFind;
long lResult = 0;

lResult = _findfirst("*.txt", &sFind);
if (lResult == -1) {
cout << "没有找到文件。" << endl;
return 0;
}

do{
cout << sFind.name << endl;
cout << sFind.size << endl;
cout << lResult << endl;
} while(_findnext(lResult, &sFind) != -1);

// 文件内容读取,得看内内容是什么样的了。
return 0;
}

#6


引用 5 楼 zjq9931 的回复:

#include 
#include 
#include 
using namespace std;

int main() {
_finddata_t sFind;
long lResult = 0;

lResult = _findfirst("*.txt", &sFind);
if (lResult == -1) {
cout << "没有找到文件。" << endl;
return 0;
}

do{
cout << sFind.name << endl;
cout << sFind.size << endl;
cout << lResult << endl;
} while(_findnext(lResult, &sFind) != -1);

// 文件内容读取,得看内内容是什么样的了。
return 0;
}



谢谢你!我刚才调试正确!
请问那怎么和这个txt的最大值连起来呢,这个txt的最大值用函数求出来了,比如我调用这个函数怎么调用。我问题比较多,大神谅解哈

#7


引用 6 楼 CSDN______ 的回复:
Quote: 引用 5 楼 zjq9931 的回复:


#include 
#include 
#include 
using namespace std;

int main() {
_finddata_t sFind;
long lResult = 0;

lResult = _findfirst("*.txt", &sFind);
if (lResult == -1) {
cout << "没有找到文件。" << endl;
return 0;
}

do{
cout << sFind.name << endl;
cout << sFind.size << endl;
cout << lResult << endl;
} while(_findnext(lResult, &sFind) != -1);

// 文件内容读取,得看内内容是什么样的了。
return 0;
}



谢谢你!我刚才调试正确!
请问那怎么和这个txt的最大值连起来呢,这个txt的最大值用函数求出来了,比如我调用这个函数怎么调用。我问题比较多,大神谅解哈


打开文件,用fscanf可以将文本文件里面每一个字符,转换成数值。
然后相加,计算。
你自己写,遇到什么问题,再来问就好。
这样最容易沟通。

#8


system("dir /b /a-d c:\\*.* >d:\\allfiles.txt");
//读文件d:\\allfiles.txt的内容即C:\\下所有文件的名字
system("dir /b /a-d /s c:\\*.* >d:\\allfilesinsub.txt");
//读文件d:\\allfilesinsub.txt的内容即C:\\下所有文件的名字包含子目录
system("dir /b /ad  c:\\*.* >d:\\alldirs.txt");
//读文件d:\\alldirs.txt的内容即C:\\下所有子目录的名字
请记住,能用shell命令获取文件、文件夹信息或者操作文件、文件夹最好用shell命令获取或者操作,而不要用各种API获取或者操作,因为当遇到非法文件夹名或非法文件名或非法文件长度、非法文件日期、压缩文件、链接文件、稀疏文件……等各种意料之外的情况时,API会处理的不全面或陷入死循环,而shell命令不会。
如果嫌system黑窗口一闪,将system("...")替换为WinExec("cmd /c ...",SW_HIDE);

#9


读txt的代码我会,cout<

#10


仅供参考:
//将c:\\tmp文件夹下的所有文件的内容全部放到用malloc分配的内存中
#include 
#include 
#include 
#include 
struct FB {
    char fn[256];
    size_t fl;
    char *b;
    struct FB *next;
    struct FB *prev;
} *fh,*fb,*ft;
char ln[256];
char fpn[256];
FILE *af;
FILE *f;
int L,n;
int main() {
    system("dir /b /a-d c:\\tmp\\*.* >c:\\allfn.txt");
    af=fopen("c:\\allfn.txt","r");
    if (NULL==af) {
        printf("Can not open file c:\\allfn.txt!\n");
        return 1;
    }
    fh=NULL;
    fb=NULL;
    n=0;
    while (1) {
        if (NULL==fgets(ln,256,af)) break;
        L=strlen(ln);
        if ('\n'==ln[L-1]) ln[L-1]=0;
        printf("read %s\n",ln);
        strcpy(fpn,"c:\\tmp\\");
        strcat(fpn,ln);
        ft=(struct FB *)malloc(sizeof(struct FB));
        if (NULL==ft) {
            printf("Can not malloc ft!\n");
            fclose(af);
            return 2;//之前的malloc在main退出后由操作系统自动free
        }
        printf("ft[%d]==%p\n",n,ft);
        strcpy(ft->fn,fpn);
        f=fopen(fpn,"rb");
        if (NULL==f) {
            printf("Can not open file %s!\n",fpn);
            fclose(af);
            return 3;//之前的malloc在main退出后由操作系统自动free
        }
        ft->fl=_filelength(fileno(f));
        ft->b=malloc(ft->fl);
        if (NULL==ft->b) {
            printf("Can not malloc ft->b!\n");
            fclose(f);
            fclose(af);
            return 4;//之前的malloc在main退出后由操作系统自动free
        }
        printf("ft[%d]->b==%p\n",n,ft->b);
        if (ft->fl!=fread(ft->b,1,ft->fl,f)) {
            printf("fread error!\n");
            fclose(f);
            fclose(af);
            return 5;//之前的malloc在main退出后由操作系统自动free
        }
        fclose(f);
        ft->next=NULL;

        if (NULL==fh) {
            ft->prev=NULL;
            fh=ft;
        } else {
            fb->next=ft;
            ft->prev=fb;
        }
        fb=ft;
        n++;
    }
    fclose(af);
    printf("-----list-----\n");
    for (ft=fh;NULL!=ft;ft=ft->next) {
        printf("%8d %s\n",ft->fl,ft->fn);
        if (NULL!=ft) fb=ft;
    }
    printf("-----free-----\n");
    n--;
    if (NULL!=fh) {
        for (ft=fb->prev;NULL!=ft;ft=ft->prev) {
            if (NULL!=ft->next->b) {
                printf("ft[%d]->b==%p\n",n,ft->next->b);
                free(ft->next->b);
            }
            if (NULL!=ft->next) {
                printf("ft[%d]==%p\n",n,ft->next);
                free(ft->next);
            }
            n--;
        }
        if (NULL!=fh->b) {
            printf("ft[0]->b==%p\n",fh->b);
            free(fh->b);
        }
        printf("ft[0]==%p\n",fh);
        free(fh);
    }
    return 0;
}
//C:\tmp\tmp\Debug>dir /a-d c:\tmp
// 驱动器 C 中的卷是 C_HD5_1
// 卷的序列号是 1817-D526
//
// c:\tmp 的目录
//
//找不到文件
//
//C:\tmp\tmp\Debug>tmp
//找不到文件
//-----list-----
//-----free-----
//
//C:\tmp\tmp\Debug>dir /a-d c:\tmp
// 驱动器 C 中的卷是 C_HD5_1
// 卷的序列号是 1817-D526
//
// c:\tmp 的目录
//
//2011-06-30  18:04            44,840 my_c.rar
//2011-06-30  17:18             1,036 err.frm
//2011-06-30  14:32            14,243 出租.txt
//2011-06-28  12:08            23,681 MSDN98书签.txt
//             4 个文件         83,800 字节
//             0 个目录 17,041,870,848 可用字节
//
//C:\tmp\tmp\Debug>tmp
//read my_c.rar
//ft[0]==00421800
//ft[0]->b==00520068
//read err.frm
//ft[1]==00421670
//ft[1]->b==0052AFC0
//read 出租.txt
//ft[2]==00421530
//ft[2]->b==00378F28
//read MSDN98书签.txt
//ft[3]==004213F0
//ft[3]->b==0052B3F8
//-----list-----
// 44840 c:\tmp\my_c.rar
//  1036 c:\tmp\err.frm
// 14243 c:\tmp\出租.txt
// 23681 c:\tmp\MSDN98书签.txt
//-----free-----
//ft[3]->b==0052B3F8
//ft[3]==004213F0
//ft[2]->b==00378F28
//ft[2]==00421530
//ft[1]->b==0052AFC0
//ft[1]==00421670
//ft[0]->b==00520068
//ft[0]==00421800
//
//C:\tmp\tmp\Debug>

#11


引用 9 楼 CSDN______ 的回复:
读txt的代码我会,cout<

路径直接填写:sFind.name
就可以了。子函数里面的路径?通过参数传过去啊。

#12


我用string  char  都试了不行,也用了指针还是一样的效果。你写一下行吗,传地址的这几句,我试了一早晨还是同样的效果

#13


引用 12 楼 CSDN______ 的回复:
我用string  char  都试了不行,也用了指针还是一样的效果。你写一下行吗,传地址的这几句,我试了一早晨还是同样的效果

把你的代码片段放上来,看看你的思路。我给改一下。

#14


这是我的代码,主要是我写感叹号的地方错了
谢谢你啦

#include 
#include 
#include 
#include 
#include 
#include 
#include
 
 
using namespace std;
int Max();
int main() 
{
    _finddata_t sFind;
    long lResult = 0;
     
    lResult = _findfirst("*.txt", &sFind);
    if (lResult == -1) 
{
        cout << "没有找到文件。" << endl;
        return 0;
    }
    int c;
    do
{
        cout << sFind.name << endl;
c=Max();   //调用子函数!!!
        cout << sFind.size << endl;
        cout << lResult << endl;
    } 
while(_findnext(lResult, &sFind) != -1);
    getchar();
    // 文件内容读取,得看内内容是什么样的了。
    return 0;
}
int Max()
{
inline void makeitem(vector& item,istringstream 

&in );
//int main()
//{

    char *s= "sFind.name";
    string line;
    ifstream f("s");   //打开txt!!!
     
if(!f.is_open())
{
cout<<"error openfile"< }
    vector item;
    vector > arr;
    int num=0;
    while(!f.eof())
{
        int num=0;
        getline(f,line);
        if(line.empty())continue;
        istringstream input(line);
        item.clear();
        while(!input.eof())
{
            input>>num;
            item.push_back(num);
        }
        arr.push_back(item);
    }
    f.close();
    //output arr
    for (int i=0;i     {   
        item=arr[i];

        for (int j=0;j     {
         
    cout<         
    }
    
    cout<     }
int max[]={0};
for(int i=0;i {
    for(int j=0;j     {
if(arr[i][j]>max[i])
{
max[i]=arr[i][j];
}
    }
cout< //cout< }
int m=max[0];
for(int i=0;i {
m=(m>max[i]?m:max[i]);

}
cout< return m;
getchar();
}

#15


max函数,要增加参数

int Max( char *pFileName)
{
inline void makeitem(vector& item,istringstream 

&in );
//int main()
//{

    string line;
    ifstream f(pFileName);   //打开txt!!!
     
if(!f.is_open())
{
cout<<"error openfile"< }

调用的时候这样调用
max(sFind.name);

读取文件内容那段,可以用这样

int iReader
while(1) {
    f >> iReader
    if(f.eof()) {
        break;
    }
   cout << iReader << endl;
   // 处理数值
}
直接读取内容

#16


非常感谢!很棒!

推荐阅读
  • Go Cobra命令行工具入门教程
    本文介绍了Go语言实现的命令行工具Cobra的基本概念、安装方法和入门实践。Cobra被广泛应用于各种项目中,如Kubernetes、Hugo和Github CLI等。通过使用Cobra,我们可以快速创建命令行工具,适用于写测试脚本和各种服务的Admin CLI。文章还通过一个简单的demo演示了Cobra的使用方法。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • SpringBoot uri统一权限管理的实现方法及步骤详解
    本文详细介绍了SpringBoot中实现uri统一权限管理的方法,包括表结构定义、自动统计URI并自动删除脏数据、程序启动加载等步骤。通过该方法可以提高系统的安全性,实现对系统任意接口的权限拦截验证。 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • 本文详细介绍了Spring的JdbcTemplate的使用方法,包括执行存储过程、存储函数的call()方法,执行任何SQL语句的execute()方法,单个更新和批量更新的update()和batchUpdate()方法,以及单查和列表查询的query()和queryForXXX()方法。提供了经过测试的API供使用。 ... [详细]
  • 第四章高阶函数(参数传递、高阶函数、lambda表达式)(python进阶)的讲解和应用
    本文主要讲解了第四章高阶函数(参数传递、高阶函数、lambda表达式)的相关知识,包括函数参数传递机制和赋值机制、引用传递的概念和应用、默认参数的定义和使用等内容。同时介绍了高阶函数和lambda表达式的概念,并给出了一些实例代码进行演示。对于想要进一步提升python编程能力的读者来说,本文将是一个不错的学习资料。 ... [详细]
  • 这是一个愚蠢的问题,但我只是对此感到好奇.假设我在Pythonshell,我有一些我查询的数据库对象.我做:db.query(的queryString)该查询在0xffdf842c ... [详细]
  • 如何查询zone下的表的信息
    本文介绍了如何通过TcaplusDB知识库查询zone下的表的信息。包括请求地址、GET请求参数说明、返回参数说明等内容。通过curl方法发起请求,并提供了请求示例。 ... [详细]
  • 本文介绍了设计师伊振华受邀参与沈阳市智慧城市运行管理中心项目的整体设计,并以数字赋能和创新驱动高质量发展的理念,建设了集成、智慧、高效的一体化城市综合管理平台,促进了城市的数字化转型。该中心被称为当代城市的智能心脏,为沈阳市的智慧城市建设做出了重要贡献。 ... [详细]
  • 本文讨论了使用差分约束系统求解House Man跳跃问题的思路与方法。给定一组不同高度,要求从最低点跳跃到最高点,每次跳跃的距离不超过D,并且不能改变给定的顺序。通过建立差分约束系统,将问题转化为图的建立和查询距离的问题。文章详细介绍了建立约束条件的方法,并使用SPFA算法判环并输出结果。同时还讨论了建边方向和跳跃顺序的关系。 ... [详细]
  • JavaSE笔试题-接口、抽象类、多态等问题解答
    本文解答了JavaSE笔试题中关于接口、抽象类、多态等问题。包括Math类的取整数方法、接口是否可继承、抽象类是否可实现接口、抽象类是否可继承具体类、抽象类中是否可以有静态main方法等问题。同时介绍了面向对象的特征,以及Java中实现多态的机制。 ... [详细]
  • 本文介绍了为什么要使用多进程处理TCP服务端,多进程的好处包括可靠性高和处理大量数据时速度快。然而,多进程不能共享进程空间,因此有一些变量不能共享。文章还提供了使用多进程实现TCP服务端的代码,并对代码进行了详细注释。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • 李逍遥寻找仙药的迷阵之旅
    本文讲述了少年李逍遥为了救治婶婶的病情,前往仙灵岛寻找仙药的故事。他需要穿越一个由M×N个方格组成的迷阵,有些方格内有怪物,有些方格是安全的。李逍遥需要避开有怪物的方格,并经过最少的方格,找到仙药。在寻找的过程中,他还会遇到神秘人物。本文提供了一个迷阵样例及李逍遥找到仙药的路线。 ... [详细]
author-avatar
勿忘
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有