一区二区三区日韩精品-日韩经典一区二区三区-五月激情综合丁香婷婷-欧美精品中文字幕专区

分享

VC讀寫配置文件

 Jade0709 2015-07-03

        ini文件(即Initialization file),這種類型的文件中通常存放的是一個程序的初始化信息。ini文件由若干個節(jié)(Section)組成,每個Section由若干鍵(Key)組成,每個Key可以賦相應(yīng)的值。讀寫ini文件實際上就是讀寫某個的Section中相應(yīng)的Key的值,而這只要借助幾個函數(shù)即可完成。
一、向ini文件中寫入信息的函數(shù)
1. 把信息寫入系統(tǒng)的win.ini文件

BOOL WriteProfileString(
     LPCTSTR lpAppName, // 節(jié)的名字,是一個以0結(jié)束的字符串
     LPCTSTR lpKeyName, // 鍵的名字,是一個以0結(jié)束的字符串。若為NULL,則刪除整個節(jié)
     LPCTSTR lpString      // 鍵的值,是一個以0結(jié)束的字符串。若為NULL,則刪除對應(yīng)的鍵
)


2. 把信息寫入自己定義的.ini文件
BOOL WritePrivateProfileString(
     LPCTSTR lpAppName,     // 同上
     LPCTSTR lpKeyName,     // 同上
     LPCTSTR lpString,      // 同上
     LPCTSTR lpFileName     // 要寫入的文件的文件名。若該ini文件與程序在同一個目錄下,也可使用相對
           //路徑,否則需要給出絕度路徑。
)

如:
::WriteProfileString("Test","id","xym");  
//在win.ini中創(chuàng)建一個Test節(jié),并在該節(jié)中創(chuàng)建一個鍵id,其值為xym

::WritePrivateProfileString("Test","id","xym","d:\\vc\\Ex1\\ex1.ini");
//在Ex1目錄下的ex1.ini中創(chuàng)建一個Test節(jié),并在該節(jié)中創(chuàng)建一個鍵id,其值為xym

//若Ex1.ini文件與讀寫該文件的程序在同一個目錄下,則上面語句也可寫為:
::WritePrivateProfileString("Test","id","xym",".\\ex1.ini");

需要注意的是,C系列的語言中,轉(zhuǎn)義字符'\\'表示反斜線'\'。另外,當使用相對路徑時,\\前的.號不能丟掉了。

二、從ini文件中讀取數(shù)據(jù)的函數(shù)
1、從系統(tǒng)的win.ini文件中讀取信息
(1) 讀取字符串

DWORD GetProfileString(
     LPCTSTR lpAppName,           // 節(jié)名
     LPCTSTR lpKeyName,           // 鍵名,讀取該鍵的值
     LPCTSTR lpDefault,           // 若指定的鍵不存在,該值作為讀取的默認值
     LPTSTR lpReturnedString,     // 一個指向緩沖區(qū)的指針,接收讀取的字符串
     DWORD nSize                  // 指定lpReturnedString指向的緩沖區(qū)的大小
)

如:
CString str;
::GetProfileString("Test","id","Error",str.GetBuffer(20),20);

(2) 讀取整數(shù)
UINT GetProfileInt(
     LPCTSTR lpAppName,     // 同上
     LPCTSTR lpKeyName,     // 同上
     INT nDefault           // 若指定的鍵名不存在,該值作為讀取的默認值
)

如使用以下語句寫入了年齡信息:
::WriteProfileString("Test","age","25");  
//在win.ini中創(chuàng)建一個Test節(jié),并在該節(jié)中創(chuàng)建一個鍵age,其值為25

則可用以下語句讀取age鍵的值:
int age;
age=::GetProfileInt("Test","age",0);

2、從自己的ini文件中讀取信息
(1) 讀取字符串
DWORD GetPrivateProfileString(
     LPCTSTR lpAppName,           // 同1(1)
     LPCTSTR lpKeyName,           // 同1(1)
     LPCTSTR lpDefault,           // 同1(1)
     LPTSTR lpReturnedString,     // 同1(1)
     DWORD nSize,                 // 同1(1)
     LPCTSTR lpFileName           // 讀取信息的文件名。若該ini文件與程序在同一個目錄下,也可使用相      
           //對路徑,否則需要給出絕度路徑。
)

如:
CString str;
::GetPrivateProfileString("Test","id","Error",str.GetBuffer(20),20,".\\ex1.ini");
或:
::GetPrivateProfileString("Test","id","Error",str.GetBuffer(20),20,"d:\\vc\\Ex1\\ex1.ini");

(2) 讀取整數(shù)

UINT GetPrivateProfileInt(
     LPCTSTR lpAppName,     // 同上
     LPCTSTR lpKeyName,     // 同上
     INT nDefault,          // 若指定的鍵名不存在,該值作為讀取的默認值
     LPCTSTR lpFileName     // 同上
)

如使用以下語句寫入了年齡信息:
::WritePrivateProfileString("Test","age","25",".\\ex1.ini");  
//在ex1.ini中創(chuàng)建一個Test節(jié),并在該節(jié)中創(chuàng)建一個鍵age,其值為25

則可用以下語句讀取age鍵的值:
int age;
age=::GetPrivateProfileInt("Test","age",0,".\\ex1.ini");

三、 刪除鍵值或節(jié)

      回顧一下WriteProfileString函數(shù)的說明
BOOL WriteProfileString(
     LPCTSTR lpAppName, // 節(jié)的名字,是一個以0結(jié)束的字符串
     LPCTSTR lpKeyName, // 鍵的名字,是一個以0結(jié)束的字符串。若為NULL,則刪除整個節(jié)
     LPCTSTR lpString      // 鍵的值,是一個以0結(jié)束的字符串。若為NULL,則刪除對應(yīng)的鍵
)

      由此可見,要刪除某個節(jié),只需要將WriteProfileString第二個參數(shù)設(shè)為NULL即可。而要刪除某個鍵,則只需要將該函數(shù)的第三個參數(shù)設(shè)為NULL即可。這是刪除系統(tǒng)的win.ini中的節(jié)或鍵,類似的,要刪除自己定義的ini文件中的節(jié)或鍵,也可做相同的操作。
      如:
::WriteProfileString("Test",NULL,NULL);     //刪除win.ini中的Test節(jié)
::WriteProfileString("Test","id",NULL);     //刪除win.ini中的id鍵

::WritePrivateProfileString("Test",NULL,NULL,".\\ex1.ini");     //刪除ex1.ini中的Test節(jié)
::WritePrivateProfileString("Test","id",NULL,".\\ex1.ini");     //刪除ex1.ini中的id鍵

四、如何判斷一個ini文件中有多少個節(jié)
      要判斷一個ini文件中有多少個節(jié),最簡單的辦法就是將所有的節(jié)名都找出來,然后統(tǒng)計節(jié)名的個數(shù)。而要將所有的節(jié)名找出來,使用GetPrivateProfileSectionNames函數(shù)就可以了,其原型如下:
DWORD GetPrivateProfileSectionNames(
     LPTSTR lpszReturnBuffer,     // 指向一個緩沖區(qū),用來保存返回的所有節(jié)名
     DWORD nSize,                 // 參數(shù)lpszReturnBuffer的大小
     LPCTSTR lpFileName           // 文件名,若該ini文件與程序在同一個目錄下,

                                               //也可使用相對路徑,否則需要給出絕度路徑
)

下面的是用來統(tǒng)計一個ini文件中共有多少個節(jié)的函數(shù),當然,如果需要同時找到每個節(jié)中的各個鍵及其值,根據(jù)找到節(jié)名就可以很容易的得到了。


/*統(tǒng)計共有多少個節(jié)
節(jié)名的分離方法:若chSectionNames數(shù)組的第一字符是'\0'字符,則表明
有0個節(jié)。否則,從chSectionNames數(shù)組的第一個字符開始,順序往后找,
直到找到一個'\0'字符,若該字符的后繼字符不是 '\0'字符,則表明前
面的字符組成一個節(jié)名。若連續(xù)找到兩個'\0'字符,則統(tǒng)計結(jié)束*/


int CTestDlg::CalcCount(void)
{
TCHAR      chSectionNames[2048]={0};      //所有節(jié)名組成的字符數(shù)組
char * pSectionName; //保存找到的某個節(jié)名字符串的首地址
int i;      //i指向數(shù)組chSectionNames的某個位置,從0開始,順序后移
int j=0;     //j用來保存下一個節(jié)名字符串的首地址相對于當前i的位置偏移量
int count=0;     //統(tǒng)計節(jié)的個數(shù)

//CString name;
//char id[20];
::GetPrivateProfileSectionNames(chSectionNames,2048,".\\ex1.ini");   
for(i=0;i<2048;i++,j++)
{
     if(chSectionNames[0]=='\0')
      break;      //如果第一個字符就是0,則說明ini中一個節(jié)也沒有
     if(chSectionNames[i]=='\0')
     {
      pSectionName=&chSectionNames[i-j]; //找到一個0,則說明從這個字符往前,減掉j個偏移量,
           //就是一個節(jié)名的首地址

      j=-1;        //找到一個節(jié)名后,j的值要還原,以統(tǒng)計下一個節(jié)名地址的偏移量
           //賦成-1是因為節(jié)名字符串的最后一個字符0是終止符,不能作為節(jié)名

           //的一部分
      /*::GetPrivateProfileString(pSectionName,"id","Error",id,20,".\\ex1.ini");
      name.Format("%s",id);*/   
      //在獲取節(jié)名的時候可以獲取該節(jié)中鍵的值,前提是我們知道該節(jié)中有哪些鍵。
   
      AfxMessageBox(pSectionName);     //把找到的顯示出來

      if(chSectionNames[i+1]==0)
      {
        break;     //當兩個相鄰的字符都是0時,則所有的節(jié)名都已找到,循環(huán)終止
      }
     }   
  
}

return count;
}
        ini文件(即Initialization file),這種類型的文件中通常存放的是一個程序的初始化信息。ini文件由若干個節(jié)(Section)組成,每個Section由若干鍵(Key)組成,每個Key可以賦相應(yīng)的值。讀寫ini文件實際上就是讀寫某個的Section中相應(yīng)的Key的值,而這只要借助幾個函數(shù)即可完成。

一、向ini文件中寫入信息的函數(shù)
1. 把信息寫入系統(tǒng)的win.ini文件

BOOL WriteProfileString(
     LPCTSTR lpAppName, // 節(jié)的名字,是一個以0結(jié)束的字符串
     LPCTSTR lpKeyName, // 鍵的名字,是一個以0結(jié)束的字符串。若為NULL,則刪除整個節(jié)
     LPCTSTR lpString      // 鍵的值,是一個以0結(jié)束的字符串。若為NULL,則刪除對應(yīng)的鍵
)


2. 把信息寫入自己定義的.ini文件
BOOL WritePrivateProfileString(
     LPCTSTR lpAppName,     // 同上
     LPCTSTR lpKeyName,     // 同上
     LPCTSTR lpString,      // 同上
     LPCTSTR lpFileName     // 要寫入的文件的文件名。若該ini文件與程序在同一個目錄下,也可使用相對
           //路徑,否則需要給出絕度路徑。
)

如:
::WriteProfileString("Test","id","xym");  
//在win.ini中創(chuàng)建一個Test節(jié),并在該節(jié)中創(chuàng)建一個鍵id,其值為xym

::WritePrivateProfileString("Test","id","xym","d:\\vc\\Ex1\\ex1.ini");
//在Ex1目錄下的ex1.ini中創(chuàng)建一個Test節(jié),并在該節(jié)中創(chuàng)建一個鍵id,其值為xym

//若Ex1.ini文件與讀寫該文件的程序在同一個目錄下,則上面語句也可寫為:
::WritePrivateProfileString("Test","id","xym",".\\ex1.ini");

需要注意的是,C系列的語言中,轉(zhuǎn)義字符'\\'表示反斜線'\'。另外,當使用相對路徑時,\\前的.號不能丟掉了。

二、從ini文件中讀取數(shù)據(jù)的函數(shù)
1、從系統(tǒng)的win.ini文件中讀取信息
(1) 讀取字符串

DWORD GetProfileString(
     LPCTSTR lpAppName,           // 節(jié)名
     LPCTSTR lpKeyName,           // 鍵名,讀取該鍵的值
     LPCTSTR lpDefault,           // 若指定的鍵不存在,該值作為讀取的默認值
     LPTSTR lpReturnedString,     // 一個指向緩沖區(qū)的指針,接收讀取的字符串
     DWORD nSize                  // 指定lpReturnedString指向的緩沖區(qū)的大小
)

如:
CString str;
::GetProfileString("Test","id","Error",str.GetBuffer(20),20);

(2) 讀取整數(shù)
UINT GetProfileInt(
     LPCTSTR lpAppName,     // 同上
     LPCTSTR lpKeyName,     // 同上
     INT nDefault           // 若指定的鍵名不存在,該值作為讀取的默認值
)

如使用以下語句寫入了年齡信息:
::WriteProfileString("Test","age","25");  
//在win.ini中創(chuàng)建一個Test節(jié),并在該節(jié)中創(chuàng)建一個鍵age,其值為25

則可用以下語句讀取age鍵的值:
int age;
age=::GetProfileInt("Test","age",0);

2、從自己的ini文件中讀取信息
(1) 讀取字符串
DWORD GetPrivateProfileString(
     LPCTSTR lpAppName,           // 同1(1)
     LPCTSTR lpKeyName,           // 同1(1)
     LPCTSTR lpDefault,           // 同1(1)
     LPTSTR lpReturnedString,     // 同1(1)
     DWORD nSize,                 // 同1(1)
     LPCTSTR lpFileName           // 讀取信息的文件名。若該ini文件與程序在同一個目錄下,也可使用相      
           //對路徑,否則需要給出絕度路徑。
)

如:
CString str;
::GetPrivateProfileString("Test","id","Error",str.GetBuffer(20),20,".\\ex1.ini");
或:
::GetPrivateProfileString("Test","id","Error",str.GetBuffer(20),20,"d:\\vc\\Ex1\\ex1.ini");

(2) 讀取整數(shù)

UINT GetPrivateProfileInt(
     LPCTSTR lpAppName,     // 同上
     LPCTSTR lpKeyName,     // 同上
     INT nDefault,          // 若指定的鍵名不存在,該值作為讀取的默認值
     LPCTSTR lpFileName     // 同上
)

如使用以下語句寫入了年齡信息:
::WritePrivateProfileString("Test","age","25",".\\ex1.ini");  
//在ex1.ini中創(chuàng)建一個Test節(jié),并在該節(jié)中創(chuàng)建一個鍵age,其值為25

則可用以下語句讀取age鍵的值:
int age;
age=::GetPrivateProfileInt("Test","age",0,".\\ex1.ini");

三、 刪除鍵值或節(jié)

      回顧一下WriteProfileString函數(shù)的說明
BOOL WriteProfileString(
     LPCTSTR lpAppName, // 節(jié)的名字,是一個以0結(jié)束的字符串
     LPCTSTR lpKeyName, // 鍵的名字,是一個以0結(jié)束的字符串。若為NULL,則刪除整個節(jié)
     LPCTSTR lpString      // 鍵的值,是一個以0結(jié)束的字符串。若為NULL,則刪除對應(yīng)的鍵
)

      由此可見,要刪除某個節(jié),只需要將WriteProfileString第二個參數(shù)設(shè)為NULL即可。而要刪除某個鍵,則只需要將該函數(shù)的第三個參數(shù)設(shè)為NULL即可。這是刪除系統(tǒng)的win.ini中的節(jié)或鍵,類似的,要刪除自己定義的ini文件中的節(jié)或鍵,也可做相同的操作。
      如:
::WriteProfileString("Test",NULL,NULL);     //刪除win.ini中的Test節(jié)
::WriteProfileString("Test","id",NULL);     //刪除win.ini中的id鍵

::WritePrivateProfileString("Test",NULL,NULL,".\\ex1.ini");     //刪除ex1.ini中的Test節(jié)
::WritePrivateProfileString("Test","id",NULL,".\\ex1.ini");     //刪除ex1.ini中的id鍵

四、如何判斷一個ini文件中有多少個節(jié)
      要判斷一個ini文件中有多少個節(jié),最簡單的辦法就是將所有的節(jié)名都找出來,然后統(tǒng)計節(jié)名的個數(shù)。而要將所有的節(jié)名找出來,使用GetPrivateProfileSectionNames函數(shù)就可以了,其原型如下:
DWORD GetPrivateProfileSectionNames(
     LPTSTR lpszReturnBuffer,     // 指向一個緩沖區(qū),用來保存返回的所有節(jié)名
     DWORD nSize,                 // 參數(shù)lpszReturnBuffer的大小
     LPCTSTR lpFileName           // 文件名,若該ini文件與程序在同一個目錄下,

                                               //也可使用相對路徑,否則需要給出絕度路徑
)

下面的是用來統(tǒng)計一個ini文件中共有多少個節(jié)的函數(shù),當然,如果需要同時找到每個節(jié)中的各個鍵及其值,根據(jù)找到節(jié)名就可以很容易的得到了。


/*統(tǒng)計共有多少個節(jié)
節(jié)名的分離方法:若chSectionNames數(shù)組的第一字符是'\0'字符,則表明
有0個節(jié)。否則,從chSectionNames數(shù)組的第一個字符開始,順序往后找,
直到找到一個'\0'字符,若該字符的后繼字符不是 '\0'字符,則表明前
面的字符組成一個節(jié)名。若連續(xù)找到兩個'\0'字符,則統(tǒng)計結(jié)束*/


int CTestDlg::CalcCount(void)
{
TCHAR      chSectionNames[2048]={0};      //所有節(jié)名組成的字符數(shù)組
char * pSectionName; //保存找到的某個節(jié)名字符串的首地址
int i;      //i指向數(shù)組chSectionNames的某個位置,從0開始,順序后移
int j=0;     //j用來保存下一個節(jié)名字符串的首地址相對于當前i的位置偏移量
int count=0;     //統(tǒng)計節(jié)的個數(shù)

//CString name;
//char id[20];
::GetPrivateProfileSectionNames(chSectionNames,2048,".\\ex1.ini");   
for(i=0;i<2048;i++,j++)
{
     if(chSectionNames[0]=='\0')
      break;      //如果第一個字符就是0,則說明ini中一個節(jié)也沒有
     if(chSectionNames[i]=='\0')
     {
      pSectionName=&chSectionNames[i-j]; //找到一個0,則說明從這個字符往前,減掉j個偏移量,
           //就是一個節(jié)名的首地址

      j=-1;        //找到一個節(jié)名后,j的值要還原,以統(tǒng)計下一個節(jié)名地址的偏移量
           //賦成-1是因為節(jié)名字符串的最后一個字符0是終止符,不能作為節(jié)名

           //的一部分
      /*::GetPrivateProfileString(pSectionName,"id","Error",id,20,".\\ex1.ini");
      name.Format("%s",id);*/   
      //在獲取節(jié)名的時候可以獲取該節(jié)中鍵的值,前提是我們知道該節(jié)中有哪些鍵。
   
      AfxMessageBox(pSectionName);     //把找到的顯示出來

      if(chSectionNames[i+1]==0)
      {
        break;     //當兩個相鄰的字符都是0時,則所有的節(jié)名都已找到,循環(huán)終止
      }
     }   
  
}

return count;
}

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多

    国产精品亚洲精品亚洲| 国产一级二级三级观看| 真实偷拍一区二区免费视频| 少妇淫真视频一区二区| 国产精品一级香蕉一区| 日韩一区欧美二区国产| 中文字幕日韩欧美亚洲午夜| 精品人妻av区波多野结依| 91天堂素人精品系列全集 | 欧美午夜色视频国产精品| 好吊妞视频只有这里有精品| 国产精欧美一区二区三区久久| 欧美一区日韩一区日韩一区| 亚洲第一区欧美日韩在线| 一区二区三区在线不卡免费| 国产传媒免费观看视频| 欧美丝袜诱惑一区二区| 国产av一区二区三区久久不卡| 国产亚洲精品香蕉视频播放| 亚洲综合色在线视频香蕉视频| 久久女同精品一区二区| 老司机精品一区二区三区| 五月激情五月天综合网| 国产在线视频好看不卡| 亚洲精品一区二区三区日韩| 免费啪视频免费欧美亚洲| 欧美日韩校园春色激情偷拍| 久久精品a毛片看国产成人| 日韩特级黄色大片在线观看| 日本免费一级黄色录像| 日本高清一道一二三区四五区| 九九九热视频免费观看| 午夜福利视频日本一区| 91偷拍视频久久精品| 好吊视频有精品永久免费| 中国美女偷拍福利视频| 欧美视频在线观看一区| 国产爆操白丝美女在线观看| 欧美二区视频在线观看| 国产精品午夜福利免费在线| 日韩国产中文在线视频|