1. 程式人生 > >VC++ 根據關鍵字或者部分檔名查詢檔案

VC++ 根據關鍵字或者部分檔名查詢檔案

主要用到的類 CFIleFind,參考資料http://blog.sina.com.cn/s/blog_61053f850100eu09.html

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();    //URL串
      ::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:隱藏檔案

DeleteFile(PATH)刪除檔案


部分程式碼

char cFile[_MAX_PATH*2];
	memset(cFile,0,sizeof(cFile));
	GetModuleFileNameA(NULL, cFile, _MAX_PATH*2);
	for (int i=strlen(cFile); i>0; i--)
	{
		if (cFile[i] == '\\')
		{
			cFile[i] = 0;
			break;
		}
		cFile[i] = 0;
	}
	m_strDirPath = cFile;
	m_strDirPath +=  ("\\");
	std::string strFilePath = m_strDirPath + ("XVR單板資訊列表*");
	//string轉成TCHAR *
	CString strMfc;
	strMfc=strFilePath.c_str();
	CString FilePath;//檔案存放的路徑
	FilePath= m_strDirPath.c_str();
#if 1
	CFileFind filefd;//檔案查詢類
	BOOL bContinue = filefd.FindFile(strMfc,0); //1
	CString FindFileName;//找到的檔名
	if (bContinue)
	{
		bContinue=filefd.FindNextFile();//必須加這個才能得到找到檔案的名字
		FindFileName = filefd.GetFileName();
	}
	CString ExcelName = FilePath+FindFileName; //配置檔案的絕對路徑

=================================================================================================================