c语言中循环输出到外部文件夹,node.js与C语言 实现遍历文件夹下最大的文件,并输出路径,大小...

node.js版

遍历文件夹下最大的文件,并输出路径,大小

实现代码:

文件夹下最大的文件,并输出路径,大小

*/

function findmax(basepath){

//只能执行一次

if(findmax.s) return;

findmax.s = true;

var fs = require('fs');

var maxfile = 0;

var count = 0;

var begin = new Date().getTime();

function Traversal(filepath){

fs.readdir(filepath,function(err,files){

if(err) return;

files.forEach(function(file,index,files){

//console.log(index + "=" + filepath +"\" + file);

var tmppath = filepath +"\" + file;

fs.stat(tmppath,function (err,stats) {

if (err) {

console.log("打开文件错误" + err);

return;

};

if(stats.isDirectory()) Traversal(tmppath);

else {

//console.log(++count +" "+ tmppath + " " + stats.size);

count++;

if(maxfile < stats.size)

maxfile = stats.size;

}

});

});

});

}

Traversal(basepath);

process.on('exit',function () {

var end = new Date().getTime();

console.log(count + '结束耗时:' + (end - begin) + "ms " + maxfile);

});

console.log(basepath);

}

findmax('D:\devtools\');

C/C++实现代码

#include #include DWORD maxsize = 0;

clock_t start,end;

DWORD count = 0;

void find(char lpPath)

{

char szFind[MAX_PATH],szFile[MAX_PATH];

DWORD tmpsize = 0;

WIN32_FIND_DATA FindFileData;

strcpy(szFind,lpPath);

strcat(szFind,"\*.");

HANDLE hFind=FindFirstFile(szFind,&FindFileData);

if(INVALID_HANDLE_VALUE == hFind) return;

while(TRUE)

{

if(FindFileData.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY)//如果为目录

{

if(FindFileData.cFileName[0] != '.') //判断是否为. or ..

{

strcpy(szFile,lpPath);

strcat(szFile,"\");

strcat(szFile,FindFileData.cFileName);

find(szFile);//递归调用

}

}else{

//printf("%s\n",FindFileData.cFileName);

count++;//文件计数

tmpsize = FindFileData.nFileSizeLow;

if(maxsize < tmpsize) maxsize = tmpsize;

}

//下一个文件为空,则退出

if(!FindNextFile(hFind,&FindFileData)) break;

}

}

void main()

{

char filepath[MAX_PATH]="d:\devtools";

printf("%s\n",filepath);

start = clock();

find(filepath);

end = clock();

printf("文件数:%d %dms max File:%d",count,end - start,maxsize);

//system("PAUSE");

}

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

总结

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

小编个人微信号 jb51ccc

喜欢与人分享编程技术与工作经验,欢迎加入编程之家官方交流群!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值