例如:在D:\test.ini文件中
[Font] name=宋体 size= 12pt color = RGB(255,0,0)
上面的=号两边可以加空格,也可以不加
用GetPrivateProfileInt()和GetPrivateProfileString()
[section] key=string . . 获取integer UINT GetPrivateProfileInt( LPCTSTR lpAppName, // section name LPCTSTR lpKeyName, // key name INT nDefault, // return value if key name not found LPCTSTR lpFileName // initialization file name ); 注意:lpAppName和lpKeyName不区分大小写,当获得integer <0,那么返回0。lpFileName 必须是绝对路径,因相对路径是以C:\windows DWORD GetPrivateProfileString( LPCTSTR lpAppName, // section name LPCTSTR lpKeyName, // key name LPCTSTR lpDefault, // default string LPTSTR lpReturnedString, // destination buffer DWORD nSize, // size of destination buffer LPCTSTR lpFileName // initialization file name ); 注意:lpAppName和lpKeyName不区分大小写,若lpAppName为NULL,lpReturnedString缓冲区内装载这个ini文件所有小节的列表,若为lpKeyName=NULL,就在lpReturnedString缓冲区内装载指定小节所有项的列表。lpFileName 必须是绝对路径,因相对路径是以C:\windows\, 返回值:复制到lpReturnedString缓冲区的字符数量,其中不包括那些NULL中止字符。如lpReturnedString缓冲区不够大,不能容下全部信息,就返回nSize-1(若lpAppName或lpKeyName为NULL,则返回nSize-2) 获取某一字段的所有keys和values DWORD GetPrivateProfileSection( LPCTSTR lpAppName, // section name LPTSTR lpReturnedString, // return buffer DWORD nSize, // size of return buffer LPCTSTR lpFileName // initialization file name ); retrieves the names of all sections in an initialization file. DWORD GetPrivateProfileSectionNames( LPTSTR lpszReturnBuffer, // return buffer DWORD nSize, // size of return buffer LPCTSTR lpFileName // initialization file name ); 其实就等于,GetPrivateProfileString(NULL,NULL,lpszReturnedBuffer,nSize,lpFileName)
例子:
/* test.ini "="号两边可以加空格,也可以不加 [Font] name=宋体 size= 12pt color = RGB(255,0,0) [Layout] [Body] */ CString strCfgPath = _T("D:\\test.ini"); //注意:‘\\‘ LPCTSTR lpszSection = _T("Font"); int n = GetPrivateProfileInt(_T("FONT"), _T("size"), 9, strCfgPath);//n=12 CString str; GetPrivateProfileString(lpszSection, _T("size"), _T("9pt"), str.GetBuffer(MAX_PATH), MAX_PATH, strCfgPath); str.ReleaseBuffer();//str="12pt" TCHAR buf[200] = { 0 }; int nSize = sizeof(buf) / sizeof(buf[0]); GetPrivateProfileString(lpszSection, NULL, _T(""), buf, nSize, strCfgPath); //buf: "name\0size\0color\0\0" memset(buf, 0, sizeof(buf)); GetPrivateProfileString(NULL, _T("size"), _T(""), buf, nSize, strCfgPath);//没Section,_T("size")没意义了,所以可以写NULL //可以是 GetPrivateProfileString(NULL, NULL, _T(""), buf, nSize, strCfgPath); //buf: "Font\0Layout\0Body\0\0" memset(buf, 0, sizeof(buf)); GetPrivateProfileSection(lpszSection, buf, nSize, strCfgPath); //buf: "name=宋体\0size=12pt\0color=RGB(255,0,0)\0\0" 此时“=”两边不会有空格 memset(buf, 0, sizeof(buf)); GetPrivateProfileSectionNames(buf, nSize, strCfgPath);//等于GetPrivateProfileString(NULL, NULL, _T(""), buf, nSize, strCfgPath); //buf: "Font\0Layout\0Body\0\0"
WritePrivateProfileString函数,没有写integer的,可以转成string再写入。
BOOL WritePrivateProfileString( LPCTSTR lpAppName, // section name LPCTSTR lpKeyName, // key name LPCTSTR lpString, // string to add LPCTSTR lpFileName // initialization file ); The WritePrivateProfileSection function replaces the keys and values for the specified section in an initialization file. BOOL WritePrivateProfileSection( LPCTSTR lpAppName, // section name LPCTSTR lpString, // data LPCTSTR lpFileName // file name );
WritePrivateProfileString:
If the lpFileName parameter does not contain a full path and file name for the file, WritePrivateProfileString searches the Windows directory for the file. If the file does not exist, this function creates the file in the Windows directory.
If lpFileName contains a full path and file name and the file does not exist, WritePrivateProfileString creates the file. The specified directory must already exist.
WritePrivateProfileSection:
The data in the buffer pointed to by the lpString parameter consists of one or more null-terminated strings, followed by a final null character. Each string has the following form:
key=string
The WritePrivateProfileSection function is not case-sensitive; the string pointed to by the lpAppName parameter can be a combination of uppercase and lowercase letters.
If no section name matches the string pointed to by the lpAppName parameter, WritePrivateProfileSection creates the section at the end of the specified initialization file and initializes the new section with the specified key name and value pairs.
WritePrivateProfileSection deletes the existing keys and values for the named section and inserts the key names and values in the buffer pointed to by the lpString parameter. The function does not attempt to correlate old and new key names; if the new names appear in a different order from the old names, any comments associated with preexisting keys and values in the initialization file will probably be associated with incorrect keys and values.
This operation is atomic; no operations that read from or write to the specified initialization file are allowed while the information is being written.
原文:https://www.cnblogs.com/htj10/p/11741895.html