『壹』 請高手指點:VC中如何寫配置文件記錄我選中的信息
設一個變數保存是不可取的,因為程序每次啟動時這個變數都是初始化的值,可以通過寫磁碟保存復選框的狀態.每次啟動程序再讀一次配置文件.如下:
簡單地創建一個config.txt(後綴名任意,反正是純文本)文件.裡面寫三行,每一行紀錄一下三個復選框的狀態比如:
1
1
1
表示三個全選中.然後在窗口啟動的初始化函數里加上讀取這個配置文件.讀進來由一個數組或者其他什麼的保存這三個數字,再在初始化復選框控制項的地方根據這三個數字是否為0來初始化對應的復選框狀態.如果有修改保存就重寫一次這個文件就好了.
『貳』 VC讀取配置文件方法都有哪些
GetProfileString,看一下這個函數的說明就知道了。
還有 GetPrivateProfileString
『叄』 怎樣用VC++寫個能讀寫配置文件的程序
本題可以使用標準的windows配置文件來做,文件名使用httpd.conf,在配置文件中Listen使用格式與要求稍有不同,為Listen= 或者Listen=8080
創建配置文件的方法
char strBuff[256]; //建立256位元組的數組
CString strFilePath; //存放文件完整路徑
GetCurrentDirectory(256,strBuff); //獲取當前工作路徑
strFilePath.Format("%s\\httpd.conf",strBuff); //配置文件完整路徑
FILE *fp = fopen(strFilePath, "r"); //讀配置文件,實際是測試文件是否存在
if(fp == NULL) //文件不存在
{
WritePrivateProfileString("CONFIG","Listen","",strFilePath); //寫Listen欄位到配置文件中
}
httpd.conf配置文件創建後內容如下:
[CONFIG]
Listen=
讀取配置文件的方法
char strBuff[256]; //建立256位元組的數組
CString strFilePath; //存放文件完整路徑
GetCurrentDirectory(256,strBuff);//獲取當前工作路徑
strFilePath.Format("%s\\httpd.conf",strBuff); //配置文件路徑
GetPrivateProfileString("CONFIG","Listen",NULL,strBuff,80,strFilePath); //讀取ini文件中Listen欄位
if (strBuff[0]==0) //欄位為空
{
WritePrivateProfileString("CONFIG","Listen","8080",strFilePath); //Listen欄位修改為8080
}
httpd.conf配置文件修改後內容如下:
[CONFIG]
Listen=8080
若滿意請及時採納,謝謝
『肆』 如何在VC中實現配置文件(ini)的讀寫
配置文件在重要性不言而喻,在我們常用的軟體中經常可以看到它的身影,它提供了程序初始化過程中一些常用的參數,並且可以手動的修改這些參數,因此使用起來非常的方便。常見的配置文件為*.ini文件。 [小節名]關鍵字=值關鍵字=值……MFC為用戶讀取ini文件提供了幾個函數,其中常用的幾個函數分別如下: 讀取信息:GetPrivateProfileString和GetPrivateProfileInt 寫入信息:WritePrivateProfileString 運用這幾個函數就可以滿足常用的對字元串和整數的讀寫操作了。為了體現MFC的封裝性以及方便使用,我們可以定義一個介面,即一個純虛類。所有的方法都由這個介面繼承而來。我們將這個純虛類命名為CCfgFile,之後我們從這個純虛類中繼承一個類(CIniFile)用來實現對ini文件的讀取。以後若是需要一些更高級的方法可以再從CCfgFile繼承出其他的類來實現。 這樣我們就可以利用CIniFile類中定義的函數來操縱ini文件了。在程序中我們需要操作ini文件中一些常用的配置參數讀寫,我們可以定義一個參數類來實現,如CParam 這里需要注意的是在程序中我們可能在很多地方都要實現配置參數的讀寫,我們不能在每個要使用的地方都通過new關鍵字來創建一個CParam對象。原因你懂的,呵呵!那麼我們可以通過定義CParam的一個靜態成員來實現,這個靜態成員通過一個靜態的成員函數來獲取。
『伍』 用C語言讀取一個文件中的內容,如何對不同的行進行解析,比如是配置文件
很簡單的
配置文件 微軟有抓們的一套解析函數
INI文件是Windows系統中一類比較重要的文件,通常用來存放系統或者應用程序的配置信息,以方便系統或者應用 程序在初始化時再次讀入。比如Windows系統中的配置文件win.ini和system.ini,它們就主要存放系統啟動或用戶登陸時的系統信息。這 項功能在方便了系統配置的同時,也為非法程序的自動運行提供了可乘之機。顯然,這類文件的重要性應該引起我們的重視。但是對於這樣的ini文件的讀寫操作 卻與普通文本文件有著種種的不同,尤其體現在編程實現上。筆者曾經嘗試用手動更改的方法在文件中加入一些項,使得自己的程序能夠在初始化時自動運行,但是 卻沒有成功,最後還是藉由編程的方法來實現了。這里主要涉及到一些API函數,而這些函數又往往不被人們所熟知,本文的任務就是在介紹這些函數的同時,用 簡單的程序作了示例,下面我們言歸正傳。
先來看幾個往配置文件中寫入信息的函數:
(1)WritePrivateProfileSection()用來在ini文件中直接向指定區域寫入鍵和值的信息,其原型如下:
BOOL WritePrivateProfileSection(
LPCTSTR lpAppName, // 指向指定欄位的字元串
LPCTSTR lpString, // 指向要寫入的鍵與值字元串
LPCTSTR lpFileName // 指向文件名稱字元串,如果不包含完整路徑,則在windows目錄下創建
);
用法示例:
WritePrivateProfileSection(_T(「windows」),_T(「load=c:\\winnt\\notepad.exe」),_T(「c:\\winnt\\win.ini」));
(2)WritePrivateProfileString()與上一個函數的不同點在於其將鍵和值分開了,原型如下:
BOOL WritePrivateProfileString(
LPCTSTR lpAppName, // 指向指定欄位的字元串
LPCTSTR lpKeyName, // 指向指定鍵的字元串
LPCTSTR lpString, // 指向指定值的字元串
LPCTSTR lpFileName // 指向文件名稱字元串
);
用法示例:
WritePrivateProfileString(_T(「windows」),_T(load」)_T(「c:\\winnt\\notepad.exe」),_T(「c:\\winnt\\win.ini」));
(3)WritePrivateProfileStruct()與前面兩個的不同在於文件尾有校驗和,原型如下:
BOOL WritePrivateProfileStruct(
LPCTSTR lpszSection, //指向指定欄位的字元串
LPCTSTR lpszKey, //指向指定鍵的字元串
LPVOID lpStruct, //指向存放要加入的數據的緩沖區,如果為NULL,則刪除鍵
UINT uSizeStruct, //緩沖區大小,以位元組為單位
LPCTSTR szFile //以零結尾的文件名稱字元串,如果為空,則向win.ini寫入
);
用法示例:
WritePrivateProfileStruct(_T(「windows」),_T(「load」),pBuffer,sizeof(pBuffer),_T(「c:\\winnt\\win.ini」));
(4)還有兩個函數,是專門用來向win.ini文件寫入的,函數原型如下:
BOOL WriteProfileSection(
LPCTSTR lpAppName, //指向指定欄位的字元串
LPCTSTR lpString //指向指定值的字元串
);
BOOL WriteProfileString(
LPCTSTR lpAppName, //指向指定欄位的字元串
LPCTSTR lpKeyName, //指向指定鍵的字元串
LPCTSTR lpString //指向指定值的字元串
);
下面來看幾個對應的從ini文件獲取信息的API函數,上面已經說得很詳細了,這里只說其中兩個:
DWORD GetPrivateProfileString(
LPCTSTR lpAppName, //指向指定欄位的字元串
LPCTSTR lpKeyName, //指向鍵的字元串
LPCTSTR lpDefault, //如果INI文件中沒有前兩個參數指定的欄位名或鍵名,則將此值賦給變數
LPTSTR lpReturnedString, //存放INI文件中值的目的緩存區
DWORD nSize, //目的緩沖區的大小,以位元組為單位
LPCTSTR lpFileName //指向INI文件名稱的字元串
);
UINT GetPrivateProfileInt(
LPCTSTR lpAppName, //指向指定欄位的字元串
LPCTSTR lpKeyName, //指向鍵的字元串
INT nDefault, //如果INI文件中沒有前兩個參數指定的欄位名或鍵名,則將此值賦給變數
LPCTSTR lpFileName //指向INI文件名稱的字元串
);
程序示例1: 我們在這里建立了一個應用程序「App Name」,並且使用了一個INI文件「appname.ini」,在此INI文件中,我們寫入如下內容:
[Section1]
FirstKey = It all worked out okay.
SecondKey = By golly, it works.
ThirdKey = Another test.
代碼分析如下:
#include <stdio.h>
#include <windows.h>
//主函數
main()
{
//定義局部
CHAR inBuf[80];
HKEY hKey1, hKey2;
DWORD dwDisposition;
LONG lRetCode;
// 試圖創建INI文件的鍵值
lRetCode = RegCreateKeyEx ( HKEY_LOCAL_MACHINE,
"SOFTWARE\\Microsoft\\Windows NT
\\CurrentVersion\\IniFileMapping\\appname.ini",
0, NULL, REG_OPTION_NON_VOLATILE, KEY_WRITE,
NULL, &hKey1,
&dwDisposition);
//判斷是否出錯
if (lRetCode != ERROR_SUCCESS){
printf ("Error in creating appname.ini key\n");
return (0) ;
}
//試圖設置一個節區的值
lRetCode = RegSetValueEx ( hKey1,
"Section1",
0,
REG_SZ,
"USR:App Name\\Section1",
20);
//判斷是否出錯
if (lRetCode != ERROR_SUCCESS) {
printf ( "Error in setting Section1 value\n");
return (0) ;
}
//試圖創建一個應用名稱鍵值
lRetCode = RegCreateKeyEx ( HKEY_CURRENT_USER,
"App Name",
0, NULL, REG_OPTION_NON_VOLATILE, KEY_WRITE,
NULL, &hKey2,
&dwDisposition);
//判斷是否出錯
if (lRetCode != ERROR_SUCCESS) {
printf ("Error in creating App Name key\n");
return (0) ;
}
//強制系統重新讀取映射區的內容到共享內存中,以便於將來對應用程序的調用可//以找到它,而不需要重新啟動系統
WritePrivateProfileStringW( NULL, NULL, NULL, L"appname.ini" );
//向INI文件中添加一些鍵值
WritePrivateProfileString ("Section1", "FirstKey",
"It all worked out okay.", "appname.ini");
WritePrivateProfileString ("Section1", "SecondKey",
"By golly, it works.", "appname.ini");
WritePrivateProfileSection ("Section1", "ThirdKey = Another Test.",
"appname.ini");
//測試一下添加的正確性
GetPrivateProfileString ("Section1", "FirstKey",
"Bogus Value: Get didn't work", inBuf, 80,
"appname.ini");
printf ("%s", inBuf);
return(0);
}
程序示例2:通過修改win.ini中的欄位[windows]中的鍵load或run,或者是為system.ini中的欄位[boot]中的鍵 shell增加值,可以達到設置程序自動運行的目的。假設我們要自動運行notepad.exe,修改後的win.ini或system.ini文件象這 樣就可以:
win.ini
[windows]
load=c:\winnt\notepad.exe
run=c:\winnt\notepad.exe
system.ini
[boot]
shell=c:\winnt\explorer.exe c:\winnt\notepad.exe
注意:system.ini文件的修改要特別注意,如果你單純改成shell=c:\winnt\notepad.exe,則不能首先運行 explorer.exe,很明顯你將看不到桌面和任務欄,呵呵,筆者在做實驗時就曾因為粗心造成了這樣的後果,不過不用害怕,只要你用我們下面提供的程 序,將它修改過來就可以了,默認時,系統在system.ini中的[boot]下是shell=c:\winnt\explorer.exe。很多非法 程序就是通過修改這兩個文件來達到自啟動的目的的。
下面這個程序可以在附書光碟中找到,名稱為「AutoPlay」,使用VC++6.0寫成,核心程序源代碼如下:
void CAutoRunDlg::OnBrowse()
{
//只瀏覽exe文件
CfileDialog fileDlg(TRUE,_T("EXE"),_T("*.exe"),OFN_HIDEREADONLY|OFN_OVERWRITEPROMPT,(_T("Executable Files (*.exe) |*.exe ||")));//顯示打開文件的對話框
//當操作者選擇OK時,程序取得選擇文件的全路徑名(包括文件的路徑及文件名稱),並將相應的數值傳輸給相關的控制項變數。
if(fileDlg.DoModal()==IDOK)
{
m_strFileName=fileDlg.GetPathName();
//向將變數中的數值傳輸給控制項顯示出來。
UpdateData(FALSE);
}
}
void CAutoRunDlg::OnApply()
{
//更新數據
UpdateData(TRUE);
//寫入ini文件
LPCTSTR filename;
filename=m_strFileName;
WritePrivateProfileString(_T("windows"),_T("load"),filename,_T("c:\\winnt\\win.ini"));
}
您如果要更改system.ini,可以將WritePrivateProfileString(_T("windows"),_T("load"),filename,_T("c:\\winnt\\win.ini"));
改為 WritePrivateProfileString(_T("boot"),_T("shell"),filename,_T("c:\\winnt \\system.ini"));並且在輸入文件名時輸入c:\winnt\explorer.exe c:\winnt\notepad.exe。
寫到這里,本文的意圖基本達到,如果您可以把某些代碼親自實現,相信讀者會有比較大的收獲。
『陸』 VC6.0做開發時,配置文件是怎麼做的用xml嗎
ini你可以用專門的api讀取,也可以自己用CFile類讀取
xml也可以,用XMLDOM.
也可以用注冊表...
甚至你自定義一個二進制文件,總之類型很多的拉...