1. 程式人生 > >c語言獲取當前工作路徑(轉)

c語言獲取當前工作路徑(轉)

-------------------------------------------------------------------------------------

Linux

-------------------------------------------------------------------------------------

函式名: getcwd
功 能: 取得當前的工作目錄
用 法: char *getcwd(char *buf, size_t size);

函式說明: getcwd()會將當前的工作目錄絕對路徑複製到引數buf所指的記憶體空間,引數size為buf的空間大小。在呼叫此函式時,buf所指的記憶體空間要足夠大,若工作目錄絕對路徑的字串長度超過引數size大小,則回值NULL,errno的值則為ERANGE。倘若引數buf為NULL,getcwd()會依引數size的大小自動配置記憶體(使用malloc()),如果引數size也為0,則getcwd()會依工作目錄絕對路徑的字串程度來決定所配置的記憶體大小,程序可以在使用完此字串後利用free()來釋放此空間。
返回值: 執行成功則將結果複製到引數buf所指的記憶體空間,或是返回自動配置的字串指標。失敗返回NULL,錯誤程式碼存於errno。

程式例:

複製程式碼
#include <stdio.h>     
 #include <unistd.h>   
 
main()   
 {   
      char buf[80];   
      getcwd(buf,sizeof(buf));   
      printf("current working directory: %s\n", buf);   
 }  
 
-------------------------------------------------------------------------------------
複製程式碼

-------------------------------------------------------------------------------------

Windows下目錄操作

-------------------------------------------------------------------------------------

1.獲得當前工作目錄

複製程式碼
char* _getcwd( char *buffer, int maxlen );
// 功  能 : 獲得當前工作目錄.
// 標頭檔案 : #include <direct.h>
// 返回值 : 成功返回指向buffer的pointer
//          失敗返回NULL,且設定errno為以下三個值之一:
//            ENODEV 無該裝置
//            ENOMEM 記憶體不夠
// ERANGE 結果超出範圍 // 注 意 : 當第一個引數為 NULL 時, 第二個引數 maxlen 長度設定無效,且函式 // 使用 malloc 分配足夠記憶體, 需要將函式返回值傳遞給 free() 函式來 // 釋放記憶體. 當第一個引數不為 NULL 時,maxlen 指定長度不夠函式返回 // 錯,設定errno為ERANGE
複製程式碼

2. 更改當前工作目錄

int _chdir( const char *dirname );
// 功  能 : 更改當前工作目錄.
// 標頭檔案 : #include <direct.h>
// 返回值 : 成功返回0
//          失敗返回-1,且設定errno如下:
//            ENOENT 該路徑不存在

3. 檔案遍歷(查詢)

複製程式碼
long _findfirst( char *filespec, struct _finddata_t *fileinfo );
// 功  能 : 提供與filespec指定入口泛式匹配的第一個檔案.通常後繼用_findnext函
//          數後續使用來完成某泛式下的檔案遍歷.
// 標頭檔案 : #include <io.h>
// 參  數 : filespec - 目標檔案規範,可以包含萬用字元
//          fileinfo - 檔案資訊buffer
// 返回值 : 成功返回唯一的搜尋控制代碼
//          出錯返回-1,且設定errno為如下值:
//            ENOENT 該泛式無法匹配
//            EINVAL 無效檔名
// 注  意 : _finddata_t 說明

struct _finddata_t
{
    unsigned attrib;
    time_t time_create;
    time_t time_access;
    time_t time_write;
    _fsize_t size;
    char name[_MAX_FNAME];
};
// 其中 :
//  unsigned atrrib :  檔案屬性的儲存位置。它儲存一個unsigned單元,用於表示檔案的
//                     屬性。檔案屬性是用位表示的,主要有以下一些:_A_ARCH(存檔)、
//                     _A_HIDDEN(隱藏)、_A_NORMAL(正常)、_A_RDONLY(只讀)、
//                     _A_SUBDIR(資料夾)、_A_SYSTEM(系統)。這些都是在<io.h>中
//                     定義的巨集,可以直接使用,而本身的意義其實是一個無符號整型
//                    (只不過這個整型應該是2的幾次冪,從而保證只有一位為1,而其他
//                     位為0)。既然是位表示,那麼當一個檔案有多個屬性時,它往往是
//                     通過位或的方式,來得到幾個屬性的綜合。例如只讀+隱藏+系統屬性,
//                     應該為:_A_HIDDEN | _A_RDONLY |_A_SYSTEM 。
// time_t time_create:這裡的time_t是一個變數型別,用來儲存檔案建立時間。
// time_t time_access: 檔案最後一次被訪問的時間。
// time_t time_write :  檔案最後一次被修改的時間。
// _fsize_t size     :  檔案的大小。這裡的_fsize_t應該可以相當於unsigned整型,表示
//                      檔案的位元組數。
// char name[_MAX_FNAME]:檔案的檔名。這裡的_MAX_FNAME是一個常量巨集,它在<stdlib.h>頭
//                        檔案中被定義,表示的是檔名的最大長度。

int _findnext( long handle, struct _finddata_t *fileinfo );
// 功  能 : 按照前面_findfirst中的泛式規則,查詢下一個符合該泛式的檔案,並以此為依據
//          修改fileinfo中的值
// 標頭檔案 : #include <io.h>
// 參  數 : long handle - 搜尋控制代碼(通常由緊靠其前的_findfirst()返回)
//          fileinfo    - 檔案資訊buffer
// 返回值 : 成功返回0
//          出錯返回-1,且設定errno為如下值:
//            ENOENT 沒有更多的符合該泛式的檔案

int _findclose( long handle );
// 功  能 : 關閉搜尋控制代碼並釋放相應資源
// 標頭檔案 : #include <io.h>
// 參  數 : long handle - 搜尋控制代碼(通常由緊靠其前的_findfirst()返回)
// 返回值 : 成功返回0
//          出錯返回-1,且設定errno為如下值:
//            ENOENT 沒有更多的符合該泛式的檔案
複製程式碼

4. 建立目錄

複製程式碼
int _mkdir( const char *dirname );
// 功  能 : 建立一個新目錄,目錄名為dirname.
// 標頭檔案 : #include <direct.h>
// 返回值 : 成功返回0
//          失敗返回-1,且設定errno為以下三個值之一:
//            EACCESS 許可權不允許
//            EEXIST   該目錄已存在
//            ENOENT   無該檔案或目錄
複製程式碼

5. 刪除目錄

複製程式碼
int _rmdir( const char *dirname );
// 功  能 : 刪除名為dirname的目錄.
// 標頭檔案 : #include <direct.h>
// 返回值 : 成功返回0
//          失敗返回-1,且設定errno為以下三個值之一:
//            EACCESS   : 許可權不允許
//            ENOTEMPTY : dirname不是資料夾;或者該資料夾不空;或
//                        者dirname為當前工作資料夾;或者dirname
//                        為當根資料夾;
//            ENOENT    : 無該檔案或目錄
複製程式碼

6. 其他操作

複製程式碼
int _access( const char *path, int mode );
// 功  能 : 測定檔案/目錄存取許可權.
// 標頭檔案 : #include <io.h>
// 參  數 : path - 檔案或者目錄
//          mode - 許可權設定,其值如下:
//                   00 Existence only 
//                   02 Write permission 
//                   04 Read permission 
//                   06 Read and write permission

int _chdrive( int drive );
// 功  能 : 更改當前工作驅動器.
// 標頭檔案 : #include <direct.h>
// 返回值 : 成功返回0
//          失敗返回-1
// 注  釋 : 引數說明
//            drive =1 :  A盤
//            drive =2 :  B盤
//           drive =3 :  C盤 ...

char* _getdcwd( int drive, char *buffer, int maxlen );
// 功  能 : 獲得指定驅動器的當前工作路徑.
// 標頭檔案 : #include <direct.h>
// 返回值 : 成功返回指向buffer的pointer
//          失敗返回NULL,且設定errno為以下三個值之一:
//            ENODEV 無該裝置
//            ENOMEM 記憶體不夠
//            ERANGE 結果超出範圍
// 注  意 : 當第一個引數為 NULL 時,該函式設定errno為ERANGE
複製程式碼

測試:

複製程式碼
// 功  能 : 列印目錄path中與模式chRE匹配的所有檔案明
// 輸  入 : path - 待列印的目錄
//          chRE - 要求匹配的正則表示式
static void printDir( const char* path, const char* chRE )
{
    char* chCurPath = getcwd( NULL, 0);              // 當前工作目錄
    printf("current work path: %s\n", chCurPath );
    
    
    int ret = _chdir( path );
    if ( ret < 0  )
    {
        perror( path );
    }


    char* newPath = getcwd( NULL, 0 );
    printf("new work path: %s\n", newPath);
    free(newPath);


    struct _finddata_t data;
    long hnd = _findfirst( chRE, &data );    // 查詢檔名與正則表示式chRE的匹配第一個檔案
                                             // 返回唯一的搜尋控制代碼
    
    if ( hnd < 0 )
    {
        perror( chRE );
    }
    
    int  nRet = (hnd <0 ) ? -1 : 1;
    
    while ( nRet >= 0 )
    {
        if ( data.attrib == _A_SUBDIR )  // 如果是目錄
            printf("   [%s]*\n", data.name );
        else
            printf("   [%s]\n", data.name );
        
        nRet = _findnext( hnd, &data );
    }
    
    _findclose( hnd );     // 關閉當前控制代碼


    chdir( chCurPath);         // 切換回之前的工作目錄
    free( chCurPath );
}
複製程式碼


地址:http://blog.csdn.net/yangalbert/article/details/7455241