1、CFileFind類的聲明文件保存在afx.h頭文件中。
2、該類的實現的功能:執行本地文件的查找(查找某個具體的文件,查找某類文件x*.x*,查找所有文件*.*)
3、CFileFind類是CGopherFileFind和CFtpFileFind類的基類。
4、CFileFind類的構造函數::CFileFind()和關閉函數::Close()我會成對使用。
5、CFileFind類的成員函數我根據其操作特性劃分為3類:查找操作類、獲得文件屬性類、判斷文件屬性類。(下面我先進行函數羅列並沒有完整的描述函數的參數)
查找操作類
::FindFile();
::FindNextFile();
獲得文件屬性類
::GetCreationTime();
::GetLastAccessTime();
::GetLastWriteTime();
::GetFileName();
::GetRoot();
::GetFilePath();
::GetFileTitle();
::GetFileURL();
::GetLength();
判斷文件屬性類
::IsArchived();
::IsCompressed();
::IsDirectory();
::IsDots();
::IsHidden();
::IsNormal();
::IsReadOnly();
::IsSystem();
::IsTemporary();
::MatchesMask();
6、CFileFind類中成員函數使用應注意的順序
在創建了CFileFind對象後,先執行::FindFile()函數,然後執行::FindNextFile(),然後選擇執行(獲得文件屬性類)的函數或者(判斷文件屬性類)函數。
7、CFileFind類成員函數的詳細分析
virtual BOOL FindFile(LPCTSTR pstrName = null,DWORD dwUnused = 0);
該函數若返回非0 則表明執行成功,0 則表明執行不成功。
pstrName:需要查找的文件名,例:“E://編程工具//VC++//MFC例子.rar”,“E://編程工具//VC++//MFC*.rar”,“E://編程工具//VC++//*.*”,也可以是NULL表示“*.*”。
dwUnused:必須為0
virtual BOOL FindNextFile();
該函數返回值非0 還有符合條件的文件, 0表示是最後一個文件。
virtual BOOL GetCreationTime(FILETIME *pFileTime) const;
virtual BOOL GetCreationTime(CTime& refTime) const;
該函數用來獲得查找到的某個文件的創建時間,返回值非0 獲得創建時間成功操作,0表示執行獲得創建時間失敗或者FindNextFile()沒有被執行的時候。
FILETIME *:容納時間的結構指針
CTime&:容納時間的對象地址
此處介紹:FILETIME和CTime相互轉換的處理方法:
FILETIME轉CTime的方法:
A、CTime對象在初始化時可以傳遞FILETIME結構
FILETIME ft;
CTime time(ft);
B、將FILETIME轉換為SYSTEMTIME,然後CTime對象在初始化時可以傳遞SYSTEMTIME結構
FILETIME ft;
SYSTEMTIME st;
BOOL bSuccess = ::FileTimeToSystemTime(&ft , &st);
CTime time(st);
CTime轉FILETIME方法:
CTime time(CTime::GetCurrentTime());
SYSTEMTIME st;
time.GetAsSystemTime(st);
FILETIME ft;
::SystemTimeToFileTime(&st,&ft);
virtual BOOL GetLastAccessTime(FILETIME *pFileTime) const;
virtual BOOL GetLastAccessTime(CTime& refTime) const;
該函數用來獲得某個文件最後被訪問的時間,非0表示執行成功,0表示執行失敗或者FindNextFile()函數沒有執行的時候。
virtual BOOL GetLastWriteTime(FILETIME *pFileTime) const;
virtual BOOL GetLastWriteTime(CTime& refTime) const;
該函數用來獲得某個文件最後被訪問的時間,非0表示執行成功,0表示執行失敗或者FindNextFile()函數沒有執行的時候。
virtual CString GetFilePath() const;
該函數用來獲得查找到的文件絕對路徑,必須在執行了FindNextFile()後該函數才能執行成功。
返回的結果是CString對象,例“E://編程工具//VC++//MFC.rar”
virtual CString GetFileName() const;
該函數用來獲得查找到的文件的全稱,必須在執行了FindNextFile()後該函數才能執行成功。
返回的結果是CString對象,例“MFC.rar”
virtual CString GetFileTitle() const;
該函數用來獲得查找到的文件的名稱,必須在執行了FindNextFile()後該函數才能執行成功。
返回的結果是CString對象,例“MFC”
virtual CString GetRoot() const;
該函數用來獲得查找到的文件的根目錄,必須在執行了FindNextFile()後該函數才能執行成功。
返回的結果是CString對象,例“E://編程工具//VC++//”
virtual CString GetFileURL() const;
該函數用來獲得查找到的文件的URL路徑,必須在執行了FindNextFile()後該函數才能執行成功。
返回的結果是CString對象,例“file://E://編程工具//VC++//MFC.rar”
DWORD GetLength() const;
該函數返回值獲得查找到的文件的長度,必須在執行了FindNextFile()後該函數才能執行成功。
BOOL IsArchived() const;
該函數用來判斷查找的文件屬性是否是檔案文件,非0表示是,0表示不是。必須在執行了FindNextFile()後該函數才能執行成功
BOOL IsCompressed() const;
該函數用來判斷查找的文件屬性是否是壓縮文件,非0表示是,0表示不是。必須在執行了FindNextFile()後該函數才能執行成功
BOOL IsDirectory() const;
該函數用來判斷查找的文件屬性是否是路徑文件,非0表示是,0表示不是。必須在執行了FindNextFile()後該函數才能執行成功
BOOL IsDots() const;
該函數用來判斷查找的文件屬性是否是“.”,“..”,非0表示是,0表示不是。必須在執行了FindNextFile()後該函數才能執行成功
BOOL IsHidden() const;
該函數用來判斷查找的文件屬性是否隱藏文件,非0表示是,0表示不是。必須在執行了FindNextFile()後該函數才能執行成功
BOOL IsNormal() const;
該函數用來判斷查找的文件屬性是否正常文件,非0表示是,0表示不是。必須在執行了FindNextFile()後該函數才能執行成功
BOOL IsReadOnly() const;
該函數用來判斷查找的文件屬性是否只讀文件,非0表示是,0表示不是。必須在執行了FindNextFile()後該函數才能執行成功
BOOL IsSystem() const;
該函數用來判斷查找的文件屬性是否系統文件,非0表示是,0表示不是。必須在執行了FindNextFile()後該函數才能執行成功
BOOL IsTemporary() const;
該函數用來判斷查找的文件屬性是否臨時文件,非0表示是,0表示不是。必須在執行了FindNextFile()後該函數才能執行成功
BOOL MatchesMask(DWORD dwMask) const;
該函數用來判斷查找的文件的綜合屬性,非0表示是,0表示不是。必須在執行了FindNextFile()後該函數才能執行成功
dwMask參數的使用方法:幾種文件屬性采用或運算(|)
文件屬性的結構定義:
FILE_ATTRIBUTE_ARCHIVE:檔案文件
FILE_ATTRIBUTE_COMPRESSED:壓縮文件
FILE_ATTRIBUTE_DIRECTORY:路徑文件
FILE_ATTRIBUTE_NORMAL:正常文件
FILE_ATTRIBUTE_READONLY:只讀文件
FILE_ATTRIBUTE_SYSTEM:系統文件
FILE_ATTRIBUTE_TEMPORARY:臨時文件
FILE_ATTRIBUTE_HIDDEN:隱藏文件
CFileFind的使用方法 轉:http://blog.csdn.net/hzyong_c/archive/2008/01/15/2044906.aspx 去年十月份,因項目需要,做了UD上傳功能,用到了CFileFind類,現在回顧一下CFileFind類的使用方法。1、遍歷一個目錄:
CFileFind ff;
if(strUDDir.Right(1) != "//")strUDDir += "//";
strUDDir += "*.*";
BOOL res = ff.FindFile(strUDDir);
while(res)
{
res = ff.FindNextFile();
// 不遍歷子目錄
if(!ff.IsDirectory() && !ff.IsDots())
{
…// 在這裡寫需要的代碼
}
}
ff.Close(); // 不要忘記關閉
2、成員函數的使用
於不常使用CFileFind類的人,對GetfilePath()和GetFileName()等函數得到的值很容易混淆,我寫了一段代碼,看執行後的結果便可知道各函數返回的結果(看不懂沒關系,後面還有個例子)。
l_strFilePath = ff.GetFilePath();
l_strFileName = ff.GetFileName();
l_nPoint = l_strFileName.ReverseFind('.'); // 因為文件名中可能出現多個'.'所以用 ReverseFind而不用Find?
l_nLength = l_strFileName.GetLength();
l_strFileExt = l_strFileName.Right(l_nLength - l_nPoint - 1);
l_strFileTitle = ff.GetFileTitle();
l_strFileUrl = ff.GetFileURL();
l_strFileRoot = ff.GetRoot();
l_dwLength = ff.GetLength();
得到的結果:
Filepath: f:/hoho/hzyong2008.doc
FileName: hzyong2008.doc
FileExe: doc
nFileTitle: hzyong2008
FileUrl: file://f:/hoho/hzyong2008.doc
FileRoot: f:/hoho
FileLength: 603648
對照代碼與上面的結果便可以知道各個函數的功能了吧!還有些成員函數沒介紹比如GetLastWriteTime(CTime& refTime ),自己慢慢體會去吧。
3、文件備份TRY
{
CopyFile(strFullName, strBackDir + strFileName, FALSE); // copy file
DeleteFile(strFullName); // delete source file
}
CATCH (CFileException, pEx)
{
AfxMessageBox("UD文件備份失敗");
}
END_CATCH
4、附
我寫了段代碼做了個小試驗來試用上面介紹到的函數:主要代碼與執行結果如下:
CFileFind ff;
CString l_strFilePath;
CString l_strFileName;
CString l_strFileExt;
CString l_strFileTitle;
CString l_strFileUrl;
CString l_strFileRoot;
DWORD l_dwLength;
CString l_strResult;
int l_nPoint;
int l_nLength;
m_strResult = "";
CString l_strDir = m_strDir; // m_strDir = "f://hoho";
if(l_strDir.Right(1) != "//")
l_strDir += "//";
l_strDir += "*.*";
BOOL res = ff.FindFile(l_strDir);
while(res)
{
res = ff.FindNextFile();
// 不遍歷子目錄
if(!ff.IsDirectory() && !ff.IsDots())
{
l_strFilePath = ff.GetFilePath();
l_strFileName = ff.GetFileName();
l_nPoint = l_strFileName.ReverseFind('.'); // 因為文件名中可能出現多個'.'所以用ReverseFind而不用Find?
l_nLength = l_strFileName.GetLength();
l_strFileExt = l_strFileName.Right(l_nLength - l_nPoint - 1);
l_strFileTitle = ff.GetFileTitle();
l_strFileUrl = ff.GetFileURL();
l_strFileRoot = ff.GetRoot();
l_dwLength = ff.GetLength();
l_strResult.Format("Filepath: %s/r/nFileName: %s/r/nFileExe: %s/r/nnFileTitle: %s/r/nFileUrl: %s/r/nFileRoot: %s/r/nFileLength: %d/r/n/r/n", l_strFilePath, l_strFileName, l_strFileExt, l_strFileTitle, l_strFileUrl, l_strFileRoot, l_dwLength);
m_strResult += l_strResult;
}
}
ff.Close();