关于C#操作INI文件的总结

原文地址为: 关于C#操作INI文件的总结

 

       INI文件其实是一种具有特定结构的文本文件,它的构成分为三部分,结构如下:

[Section1]
key 
1   =  value2
key 
1   =  value2
……
[Section2]
key 
1   =  value1
key 
2   =  value2
……

文件由若干个段落(section)组成,每个段落又分成若干个key)和值(value)。Windows系统自带的Win32API函数GetPrivateProfileString()WritePrivateProfileString()分别实现了对INI文件的读写操作,他们位于kernel32.dll下。

但是令人遗憾的是C#所使用的.NET框架下的公共类库并没有提供直接操作INI文件的类,所以唯一比较理想的方法就是调用API函数。

然后,.Net框架下的类库是基于托管代码的,而API函数是基于非托管代码的,(在运行库的控制下执行的代码称作托管代码。相反,在运行库之外运行的代码称作非托管代码。)如何实现托管代码与非托管代码之间的操作呢?.Net框架的System.Runtime.InteropServices命名空间下提供各种各样支持COM interop及平台调用服务的成员,其中最重要的属性之一DllImportAttribute可以用来定义用于访问非托管API的平台调用方法,它提供了对从非托管DLL导出的函数进行调用所必需的信息。下面就来看一下如何实现C#API函数的互操作。

读操作:

187f150d339a564820f8d112b5bf04a9.jpe [DllImport( " kernel32 " )]
187f150d339a564820f8d112b5bf04a9.jpe
private   static   extern   int  GetPrivateProfileString( string  section,  string  key,  string  defVal, StringBuilder retVal,  int  size,  string  filePath); 
187f150d339a564820f8d112b5bf04a9.jpesection:要读取的段落名
187f150d339a564820f8d112b5bf04a9.jpekey: 要读取的键
187f150d339a564820f8d112b5bf04a9.jpedefVal: 读取异常的情况下的缺省值
187f150d339a564820f8d112b5bf04a9.jperetVal: key所对应的值,如果该key不存在则返回空值
187f150d339a564820f8d112b5bf04a9.jpesize: 值允许的大小
187f150d339a564820f8d112b5bf04a9.jpefilePath: INI文件的完整路径和文件名

写操作:

187f150d339a564820f8d112b5bf04a9.jpe [DllImport( " kernel32 " )] 
187f150d339a564820f8d112b5bf04a9.jpe
private   static   extern   long  WritePrivateProfileString( string  section,  string  key,  string  val,  string  filePath); 
187f150d339a564820f8d112b5bf04a9.jpesection: 要写入的段落名
187f150d339a564820f8d112b5bf04a9.jpekey: 要写入的键,如果该key存在则覆盖写入
187f150d339a564820f8d112b5bf04a9.jpeval: key所对应的值
187f150d339a564820f8d112b5bf04a9.jpefilePath: INI文件的完整路径和文件名

       这样,在就可以使用对他们的调用,用常规的方式定义一个名为IniFile类:

 1 187f150d339a564820f8d112b5bf04a9.jpe using  System;
 2 187f150d339a564820f8d112b5bf04a9.jpe using  System.Runtime.InteropServices; 
 3 187f150d339a564820f8d112b5bf04a9.jpe using  System.Text; 
 4 187f150d339a564820f8d112b5bf04a9.jpe
 5 187f150d339a564820f8d112b5bf04a9.jpe namespace  IPVOD.Hotel.Remoting
 6 6ddc8c60e0fbc4c84711d6e81f184b23.jpe6cb0ad81180f92f974a9a04511d957cd.jpe 222530190136c9c4cfd237cc0d5cff99.jpe {
 70a89b43b4cfec2c1734b55933b95ec39.jpeff4e18edd20cadab34895e99643b2144.jpe    /**//// <summary>
 80da8e124122be94574e796f4842fd5b1.jpe    /// INI文件的操作类
 98c643f24084b69ffc939600ecb86bd91.jpe    /// </summary>

100da8e124122be94574e796f4842fd5b1.jpe    public class IniFile
110a89b43b4cfec2c1734b55933b95ec39.jpeff4e18edd20cadab34895e99643b2144.jpe    222530190136c9c4cfd237cc0d5cff99.jpe{
120da8e124122be94574e796f4842fd5b1.jpe        public string Path;
130da8e124122be94574e796f4842fd5b1.jpe
140da8e124122be94574e796f4842fd5b1.jpe        public IniFile(string path)
150a89b43b4cfec2c1734b55933b95ec39.jpeff4e18edd20cadab34895e99643b2144.jpe        222530190136c9c4cfd237cc0d5cff99.jpe{
160da8e124122be94574e796f4842fd5b1.jpe            this.Path = path;
178c643f24084b69ffc939600ecb86bd91.jpe        }

180da8e124122be94574e796f4842fd5b1.jpe        
19ff4e18edd20cadab34895e99643b2144.jpe0a89b43b4cfec2c1734b55933b95ec39.jpe        声明读写INI文件的API函数#region 声明读写INI文件的API函数 
200da8e124122be94574e796f4842fd5b1.jpe        [DllImport("kernel32")] 
210da8e124122be94574e796f4842fd5b1.jpe        private static extern long WritePrivateProfileString(string section, string key, string val, string filePath); 
220da8e124122be94574e796f4842fd5b1.jpe
230da8e124122be94574e796f4842fd5b1.jpe        [DllImport("kernel32")]
240da8e124122be94574e796f4842fd5b1.jpe        private static extern int GetPrivateProfileString(string section, string key, string defVal, StringBuilder retVal, int size, string filePath); 
250da8e124122be94574e796f4842fd5b1.jpe
260da8e124122be94574e796f4842fd5b1.jpe        [DllImport("kernel32")]
270da8e124122be94574e796f4842fd5b1.jpe        private static extern int GetPrivateProfileString(string section, string key, string defVal, Byte[] retVal, int size, string filePath);
288c643f24084b69ffc939600ecb86bd91.jpe        #endregion

290da8e124122be94574e796f4842fd5b1.jpe
300a89b43b4cfec2c1734b55933b95ec39.jpeff4e18edd20cadab34895e99643b2144.jpe        /**//// <summary>
310da8e124122be94574e796f4842fd5b1.jpe        /// 写INI文件
320da8e124122be94574e796f4842fd5b1.jpe        /// </summary>
330da8e124122be94574e796f4842fd5b1.jpe        /// <param name="section">段落</param>
340da8e124122be94574e796f4842fd5b1.jpe        /// <param name="key"></param>
358c643f24084b69ffc939600ecb86bd91.jpe        /// <param name="iValue"></param>

360da8e124122be94574e796f4842fd5b1.jpe        public void IniWriteValue(string section, string key, string iValue) 
370a89b43b4cfec2c1734b55933b95ec39.jpeff4e18edd20cadab34895e99643b2144.jpe        222530190136c9c4cfd237cc0d5cff99.jpe{
380da8e124122be94574e796f4842fd5b1.jpe            WritePrivateProfileString(section, key, iValue, this.Path);
398c643f24084b69ffc939600ecb86bd91.jpe        }

400da8e124122be94574e796f4842fd5b1.jpe
410a89b43b4cfec2c1734b55933b95ec39.jpeff4e18edd20cadab34895e99643b2144.jpe        /**//// <summary>
420da8e124122be94574e796f4842fd5b1.jpe        /// 读取INI文件
430da8e124122be94574e796f4842fd5b1.jpe        /// </summary>
440da8e124122be94574e796f4842fd5b1.jpe        /// <param name="section">段落</param>
450da8e124122be94574e796f4842fd5b1.jpe        /// <param name="key"></param>
468c643f24084b69ffc939600ecb86bd91.jpe        /// <returns>返回的键值</returns>

470da8e124122be94574e796f4842fd5b1.jpe        public string IniReadValue(string section, string key) 
480a89b43b4cfec2c1734b55933b95ec39.jpeff4e18edd20cadab34895e99643b2144.jpe        222530190136c9c4cfd237cc0d5cff99.jpe
490da8e124122be94574e796f4842fd5b1.jpe            StringBuilder temp = new StringBuilder(255); 
500da8e124122be94574e796f4842fd5b1.jpe
510da8e124122be94574e796f4842fd5b1.jpe            int i = GetPrivateProfileString(section, key, "", temp, 255this.Path); 
520da8e124122be94574e796f4842fd5b1.jpe            return temp.ToString();
538c643f24084b69ffc939600ecb86bd91.jpe        }

540da8e124122be94574e796f4842fd5b1.jpe
550a89b43b4cfec2c1734b55933b95ec39.jpeff4e18edd20cadab34895e99643b2144.jpe        /**//// <summary>
560da8e124122be94574e796f4842fd5b1.jpe        /// 读取INI文件
570da8e124122be94574e796f4842fd5b1.jpe        /// </summary>
580da8e124122be94574e796f4842fd5b1.jpe        /// <param name="Section">段,格式[]</param>
590da8e124122be94574e796f4842fd5b1.jpe        /// <param name="Key"></param>
608c643f24084b69ffc939600ecb86bd91.jpe        /// <returns>返回byte类型的section组或键值组</returns>

610da8e124122be94574e796f4842fd5b1.jpe        public byte[] IniReadValues(string section, string key)
620a89b43b4cfec2c1734b55933b95ec39.jpeff4e18edd20cadab34895e99643b2144.jpe        222530190136c9c4cfd237cc0d5cff99.jpe{
630da8e124122be94574e796f4842fd5b1.jpe            byte[] temp = new byte[255];
640da8e124122be94574e796f4842fd5b1.jpe
650da8e124122be94574e796f4842fd5b1.jpe            int i = GetPrivateProfileString(section, key, "", temp, 255this.Path);
660da8e124122be94574e796f4842fd5b1.jpe            return temp;
678c643f24084b69ffc939600ecb86bd91.jpe        }

688c643f24084b69ffc939600ecb86bd91.jpe    }

69d227570473e7889a2a5353d34a11cbc2.jpe}

70 187f150d339a564820f8d112b5bf04a9.jpe

注意:我增加了DLL导出的函数GetPrivateProfileString的重载,说明如下:

187f150d339a564820f8d112b5bf04a9.jpe [DllImport( " kernel32 " )] 
187f150d339a564820f8d112b5bf04a9.jpe
private   static   extern   int  GetPrivateProfileString( string  section,  string  key,  string  defVal, Byte[] retVal,  int  size,  string  filePath);
187f150d339a564820f8d112b5bf04a9.jpesection:要读取的段落名
187f150d339a564820f8d112b5bf04a9.jpekey: 要读取的键
187f150d339a564820f8d112b5bf04a9.jpedefVal: 读取异常的情况下的缺省值
187f150d339a564820f8d112b5bf04a9.jperetVal: 此参数类型不是string,而是Byte[]用于返回byte类型的section组或键值组。
187f150d339a564820f8d112b5bf04a9.jpesize: 值允许的大小
187f150d339a564820f8d112b5bf04a9.jpefilePath: INI文件的完整路径和文件名


下面看一下具体实例化IniFile类的操作:

//pathini文件的物理路径

IniFile ini = new IniFile(path);

//读取ini文件的所有段落名

byte[] allSection = ini.IniReadValues(null, null);

 

通过如下方式转换byte[]类型为string[]数组类型

string[] sectionList;

ASCIIEncoding ascii = new ASCIIEncoding();

//获取自定义设置section中的所有keybyte[]类型

sectionByte = ini.IniReadValues("personal", null);

//编码所有keystring类型

sections = ascii.GetString(sectionByte);

//获取key的数组

sectionList = sections.Split(new char[1]{'\0'});

 

//读取ini文件personal段落的所有键名,返回byte[]类型

byte[] sectionByte = ini.IniReadValues("personal", null);

 

//读取ini文件evideo段落的MODEL键值

model = ini.IniReadValue("evideo", "MODEL");

 

//将值eth0写入ini文件evideo段落的DEVICE

ini.IniWriteValue("evideo", "DEVICE", "eth0");

即:

[evideo]

DEVICE = eth0

 

//删除ini文件下personal段落下的所有键

ini.IniWriteValue("personal", null, null);

 

//删除ini文件下所有段落

ini.IniWriteValue(null, null, null);

这样就实现了C#对ini文件包括段落section,键key,键值value的基本上所有操作,当然这只是简单的举例,不是详细的实现,欢迎随时提出任何疑问和建议。


转载请注明本文地址: 关于C#操作INI文件的总结

猜你喜欢

转载自blog.csdn.net/w36680130/article/details/81585728