有关 FindFirstFile() 与 FindNextFile() 的问题

zhouzhipen 2009-07-07 03:09:59
用 FindFirstFile(),得到一个句柄, 然后用FindNextFile()对文件进行遍历,
问题是找到的文件是以什么顺序排列的,如果我想要找到的文件以文件名进行排列有什么方法?
例如我在一个目录下有
01.txt
06.txt
03.txt
05.txt
04.txt
02.txt
这几个文件,我希望找到的每一个文件是01.TXT,每二个是 02.TXT......
但是我发现FindNextFile 并不是每次都这样排列,有时候按这个顺序,有时候不是,有方法可以解决吗?
...全文
213 14 打赏 收藏 转发到动态 举报
写回复
用AI写文章
14 条回复
切换为时间正序
请发表友善的回复…
发表回复
zhouzhipen 2009-07-07
  • 打赏
  • 举报
回复
[Quote=引用 12 楼 byxdaz 的回复:]
TCHAR szSupportFile[][10] = {_T("*.txt")};
TCHAR sFileName[MAX_PATH];
memset(sFileName,0,sizeof(sFileName));
int iFileTot = 0,ii = 0;
HANDLE hFind;
WIN32_FIND_DATA wfd;
for(ii=0;ii <sizeof(szSupportFile)/sizeof(szSupportFile[0]);ii++)
{
swprintf(sFileName,_T("%s\\%s"),pDoc->m_strSRC,szSupportFile[ii]);
hFind = FindFirstFile(sFileName,&wfd);
if (hFind==INVALID_HA…
[/Quote]
谢谢你,给了这么长的一串代码, 如果是要自己处理排序,意义就不大了.那我还不如在每个目录下建立一个索引文件,还方便一点.不管怎样,还是谢谢你!
zhouzhipen 2009-07-07
  • 打赏
  • 举报
回复
看来只有结帖了.
byxdaz 2009-07-07
  • 打赏
  • 举报
回复
TCHAR szSupportFile[][10] = {_T("*.txt")};
TCHAR sFileName[MAX_PATH];
memset(sFileName,0,sizeof(sFileName));
int iFileTot = 0,ii = 0;
HANDLE hFind;
WIN32_FIND_DATA wfd;
for(ii=0;ii<sizeof(szSupportFile)/sizeof(szSupportFile[0]);ii++)
{
swprintf(sFileName,_T("%s\\%s"),pDoc->m_strSRC,szSupportFile[ii]);
hFind = FindFirstFile(sFileName,&wfd);
if (hFind==INVALID_HANDLE_VALUE)
{
continue;
}
else
{
do
{
iFileTot++;
}while(FindNextFile(hFind,&wfd));
}
FindClose(hFind);
}
pDoc->m_iFileTotal = iFileTot;

//保存文件名
if(pDoc->m_strFileNameList)
{
delete[] pDoc->m_strFileNameList;
pDoc->m_strFileNameList = NULL;
}
pDoc->m_strFileNameList=new CString[iFileTot+1];


iFileTot=0;
for(ii=0;ii<sizeof(szSupportFile)/sizeof(szSupportFile[0]);ii++)
{
swprintf(sFileName,_T("%s\\%s"),pDoc->m_strSRC,szSupportFile[ii]);
hFind=FindFirstFile(sFileName,&wfd);
if (hFind==INVALID_HANDLE_VALUE)
{
continue;
}
do
{
pDoc->m_strFileNameList[iFileTot] +=pDoc->m_strSRC;
pDoc->m_strFileNameList[iFileTot] +="\\";
pDoc->m_strFileNameList[iFileTot] += _wcsupr(wfd.cFileName);
iFileTot++;
}while(FindNextFile(hFind,&wfd));
FindClose(hFind);
}

//对文件名进行冒泡排序。
int i,j,m,n,k;
TCHAR tmp[64]={0};
n=iFileTot;
k=0;
m=n-1;
while (k<m)
{
j=m-1;
m=0;
for (i=k;i<=j;i++)
{
if (wcscmp(pDoc->m_strFileNameList[i],pDoc->m_strFileNameList[i+1])>0)
{
wcscpy(tmp,pDoc->m_strFileNameList[i]);
pDoc->m_strFileNameList[i]=pDoc->m_strFileNameList[i+1];
pDoc->m_strFileNameList[i+1]=tmp;
m=i;
}
}
j=k+1;
k=0;
for (i=m;i>=j;i--)
{
if (wcscmp(pDoc->m_strFileNameList[i-1],pDoc->m_strFileNameList[i])>0)
{
wcscpy(tmp,pDoc->m_strFileNameList[i]);
pDoc->m_strFileNameList[i]=pDoc->m_strFileNameList[i-1];
pDoc->m_strFileNameList[i-1]=tmp;
k=i;
}
}
}
//////////////////////////////////////////////////////////////////////////////////////////
//pDoc->m_strSRC,表示处理路径
//pDoc->m_iFileTotal,文件总数
//pDoc->m_strFileNameList,表示文件名列表
byxdaz 2009-07-07
  • 打赏
  • 举报
回复
先得到文件名,再自己排序.
一般都是这样做的.
ahao 2009-07-07
  • 打赏
  • 举报
回复
[Quote=引用 9 楼 zhouzhipen 的回复:]
引用 8 楼 healer_kx 的回复:

Windows API给你的,就是按照某种顺序给你的,想得到你自己的顺序,还是要自己写代码的。


API就是没有顺序的,一会这样的顺序,一会又那样.
[/Quote]

这个和数据库是一个道理,他不定义顺序,具体什么顺序,取决于具体数据和内部数据结构。
zhouzhipen 2009-07-07
  • 打赏
  • 举报
回复
[Quote=引用 8 楼 healer_kx 的回复:]
Windows API给你的,就是按照某种顺序给你的,想得到你自己的顺序,还是要自己写代码的。
[/Quote]

API就是没有顺序的,一会这样的顺序,一会又那样.
healer_kx 2009-07-07
  • 打赏
  • 举报
回复
Windows API给你的,就是按照某种顺序给你的,想得到你自己的顺序,还是要自己写代码的。
zhouzhipen 2009-07-07
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 zhangyan_wt 的回复:]
这是操作系统决定的,无数人的经验证明,只能自己排序,别无他法
[/Quote]
看了你条,我心都死了.
zhangyan_wt 2009-07-07
  • 打赏
  • 举报
回复
这是操作系统决定的,无数人的经验证明,只能自己排序,别无他法
zhouzhipen 2009-07-07
  • 打赏
  • 举报
回复
那为什么有时候是对的,这是什么原因造成的
fandh 2009-07-07
  • 打赏
  • 举报
回复
应该是要自己排序的!
ahao 2009-07-07
  • 打赏
  • 举报
回复
[Quote=引用 1 楼 fengrx 的回复:]
变通下:
得到后先放在数组中,然后排序。
[/Quote]
.
zhouzhipen 2009-07-07
  • 打赏
  • 举报
回复
还有没有其它的方法可行的??
fengrx 2009-07-07
  • 打赏
  • 举报
回复
变通下:
得到后先放在数组中,然后排序。

16,472

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧