如何在C#中读写INI文件
2024-07-21 02:17:59
供稿:网友
 
ini文件就是扩展名为“ini”的文件。在windows系统中,ini文件是很多,最重要的就是“system.ini”、“system32.ini”和“win.ini”。该文件主要存放用户所做的选择以及系统的各种参数。用户可以通过修改ini文件,来改变应用程序和系统的很多配置。但自从windows 95的退出,在windows系统中引入了注册表的概念,ini文件在windows系统的地位就开始不断下滑,这是因为注册表的独特优点,使应用程序和系统都把许多参数和初始化信息放进了注册表中。但在某些场合,ini文件还拥有其不可替代的地位。本文就来探讨一下c#是如何对ini进行读写操作。
ini文件的结构
ini文件是一种按照特点方式排列的文本文件。每一个ini文件构成都非常类似,由若干段落(section)组成,在每个带括号的标题下面,是若干个以单个单词开头的关键词(keyword)和一个等号,等号右边的就是关键字对应的值(value)。其一般形式如下: 
[section1]
  keyword1 = valuel
  keyword2 = value2
   ……
  [section2]
  keyword3 = value3
  keyword4 = value4
c#和win32 api函数
c#并不像c++,拥有属于自己的类库。c#使用的类库是.net框架为所有.net程序开发提供的一个共有的类库——.net framework sdk。虽然.net framework sdk内容十分庞大,功能也非常强大,但还不能面面俱到,至少它并没有提供直接操作ini文件所需要的相关的类。在本文中,c#操作ini文件使用的是windows系统自带win32的api函数——writeprivateprofilestring()和getprivateprofilestring()函数。这二个函数都位于“kernel32.dll”文件中。 
我们知道在c#中使用的类库都是托管代码(managed code)文件,而win32的api函数所处的文件,都是非托管代码(unmanaged code)文件。这就导致了在c#中不可能直接使用这些非托管代码文件中的函数。好在.net框架为了保持对下的兼容,也为了充分利用以前的资源,提出了互操作,通过互操作可以实现对win32的api函数的调用。互操作不仅适用于win32的api函数,还可以用来访问托管的com对象。c#中对win32的api函数的互操作是通过命名空间“system.runtime.interopservices”中的“dllimport”特征类来实现的。它的主要作用是指示此属性化方法是作为非托管dll的输出实现的。下面代码就是在c#利用命名空间“system.runtime.interopservices”中的“dllimport”特征类申明上面二个win32的api函数: 
c#申明ini文件的写操作函数writeprivateprofilestring(): 
[ dllimport ( "kernel32" ) ]
 private static extern long writeprivateprofilestring ( string 
section ,
 string key , string val , string filepath ) ;
参数说明:section:ini文件中的段落;key:ini文件中的关键字;val:ini文件中关键字的数值;filepath:ini文件的完整的路径和名称。 
c#申明ini文件的读操作函数getprivateprofilestring(): 
[ dllimport ( "kernel32" ) ]
 private static extern int getprivateprofilestring ( string section ,
 string key , string def , stringbuilder retval ,
 int size , string filepath ) ; 
参数说明:section:ini文件中的段落名称;key:ini文件中的关键字;def:无法读取时候时候的缺省数值;retval:读取数值;size:数值的大小;filepath:ini文件的完整路径和名称。 
 
下面是一个读写ini文件的类
public class iniclass
{
 public string inipath;
 [dllimport("kernel32")]
 private static extern long writeprivateprofilestring(string section,string key,string val,string filepath);
 [dllimport("kernel32")]
 private static extern int getprivateprofilestring(string section,string key,string def,stringbuilder retval,int size,string filepath);
 /// <summary>
 /// 构造方法
 /// </summary>
 /// <param name="inipath">文件路径</param>
 public iniclass(string inipath)
 {
 inipath = inipath;
 }
 /// <summary>
 /// 写入ini文件
 /// </summary>
 /// <param name="section">项目名称(如 [typename] )</param>
 /// <param name="key">键</param>
 /// <param name="value">值</param>
 public void iniwritevalue(string section,string key,string value)
 {
 writeprivateprofilestring(section,key,value,this.inipath);
 }
 /// <summary>
 /// 读出ini文件
 /// </summary>
 /// <param name="section">项目名称(如 [typename] )</param>
 /// <param name="key">键</param>
 public string inireadvalue(string section,string key)
 {
 stringbuilder temp = new stringbuilder(500);
 int i = getprivateprofilestring(section,key,"",temp,500,this.inipath);
 return temp.tostring();
 }
 /// <summary>
 /// 验证文件是否存在
 /// </summary>
 /// <returns>布尔值</returns>
 public bool existinifile()
 {
 return file.exists(inipath);
 }
}