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

时间:2021-02-16 08:01:04

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

 

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

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

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

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

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

读操作:

关于C#操作INI文件的总结[DllImport("kernel32")]
关于C#操作INI文件的总结private static extern int GetPrivateProfileString(string section, string key, string defVal, StringBuilder retVal, int size, string filePath); 
关于C#操作INI文件的总结section:要读取的段落名
关于C#操作INI文件的总结key: 要读取的键
关于C#操作INI文件的总结defVal: 读取异常的情况下的缺省值
关于C#操作INI文件的总结retVal: key所对应的值,如果该key不存在则返回空值
关于C#操作INI文件的总结size: 值允许的大小
关于C#操作INI文件的总结filePath: INI文件的完整路径和文件名

写操作:

关于C#操作INI文件的总结[DllImport("kernel32")] 
关于C#操作INI文件的总结private static extern long WritePrivateProfileString(string section, string key, string val, string filePath); 
关于C#操作INI文件的总结section: 要写入的段落名
关于C#操作INI文件的总结key: 要写入的键,如果该key存在则覆盖写入
关于C#操作INI文件的总结val: key所对应的值
关于C#操作INI文件的总结filePath: INI文件的完整路径和文件名

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

 1关于C#操作INI文件的总结using System;
 2关于C#操作INI文件的总结using System.Runtime.InteropServices; 
 3关于C#操作INI文件的总结using System.Text; 
 4关于C#操作INI文件的总结
 5关于C#操作INI文件的总结namespace IPVOD.Hotel.Remoting
 6关于C#操作INI文件的总结关于C#操作INI文件的总结关于C#操作INI文件的总结{
 7关于C#操作INI文件的总结关于C#操作INI文件的总结    /**//// <summary>
 8关于C#操作INI文件的总结    /// INI文件的操作类
 9关于C#操作INI文件的总结    /// </summary>
10关于C#操作INI文件的总结    public class IniFile
11关于C#操作INI文件的总结关于C#操作INI文件的总结    关于C#操作INI文件的总结{
12关于C#操作INI文件的总结        public string Path;
13关于C#操作INI文件的总结
14关于C#操作INI文件的总结        public IniFile(string path)
15关于C#操作INI文件的总结关于C#操作INI文件的总结        关于C#操作INI文件的总结{
16关于C#操作INI文件的总结            this.Path = path;
17关于C#操作INI文件的总结        }
18关于C#操作INI文件的总结        
19关于C#操作INI文件的总结关于C#操作INI文件的总结        声明读写INI文件的API函数#region 声明读写INI文件的API函数 
20关于C#操作INI文件的总结        [DllImport("kernel32")] 
21关于C#操作INI文件的总结        private static extern long WritePrivateProfileString(string section, string key, string val, string filePath); 
22关于C#操作INI文件的总结
23关于C#操作INI文件的总结        [DllImport("kernel32")]
24关于C#操作INI文件的总结        private static extern int GetPrivateProfileString(string section, string key, string defVal, StringBuilder retVal, int size, string filePath); 
25关于C#操作INI文件的总结
26关于C#操作INI文件的总结        [DllImport("kernel32")]
27关于C#操作INI文件的总结        private static extern int GetPrivateProfileString(string section, string key, string defVal, Byte[] retVal, int size, string filePath);
28关于C#操作INI文件的总结        #endregion
29关于C#操作INI文件的总结
30关于C#操作INI文件的总结关于C#操作INI文件的总结        /**//// <summary>
31关于C#操作INI文件的总结        /// 写INI文件
32关于C#操作INI文件的总结        /// </summary>
33关于C#操作INI文件的总结        /// <param name="section">段落</param>
34关于C#操作INI文件的总结        /// <param name="key">键</param>
35关于C#操作INI文件的总结        /// <param name="iValue">值</param>
36关于C#操作INI文件的总结        public void IniWriteValue(string section, string key, string iValue) 
37关于C#操作INI文件的总结关于C#操作INI文件的总结        关于C#操作INI文件的总结{
38关于C#操作INI文件的总结            WritePrivateProfileString(section, key, iValue, this.Path);
39关于C#操作INI文件的总结        }
40关于C#操作INI文件的总结
41关于C#操作INI文件的总结关于C#操作INI文件的总结        /**//// <summary>
42关于C#操作INI文件的总结        /// 读取INI文件
43关于C#操作INI文件的总结        /// </summary>
44关于C#操作INI文件的总结        /// <param name="section">段落</param>
45关于C#操作INI文件的总结        /// <param name="key">键</param>
46关于C#操作INI文件的总结        /// <returns>返回的键值</returns>
47关于C#操作INI文件的总结        public string IniReadValue(string section, string key) 
48关于C#操作INI文件的总结关于C#操作INI文件的总结        关于C#操作INI文件的总结
49关于C#操作INI文件的总结            StringBuilder temp = new StringBuilder(255); 
50关于C#操作INI文件的总结
51关于C#操作INI文件的总结            int i = GetPrivateProfileString(section, key, "", temp, 255, this.Path); 
52关于C#操作INI文件的总结            return temp.ToString();
53关于C#操作INI文件的总结        }
54关于C#操作INI文件的总结
55关于C#操作INI文件的总结关于C#操作INI文件的总结        /**//// <summary>
56关于C#操作INI文件的总结        /// 读取INI文件
57关于C#操作INI文件的总结        /// </summary>
58关于C#操作INI文件的总结        /// <param name="Section">段,格式[]</param>
59关于C#操作INI文件的总结        /// <param name="Key">键</param>
60关于C#操作INI文件的总结        /// <returns>返回byte类型的section组或键值组</returns>
61关于C#操作INI文件的总结        public byte[] IniReadValues(string section, string key)
62关于C#操作INI文件的总结关于C#操作INI文件的总结        关于C#操作INI文件的总结{
63关于C#操作INI文件的总结            byte[] temp = new byte[255];
64关于C#操作INI文件的总结
65关于C#操作INI文件的总结            int i = GetPrivateProfileString(section, key, "", temp, 255, this.Path);
66关于C#操作INI文件的总结            return temp;
67关于C#操作INI文件的总结        }
68关于C#操作INI文件的总结    }
69关于C#操作INI文件的总结}
70关于C#操作INI文件的总结

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

关于C#操作INI文件的总结[DllImport("kernel32")] 
关于C#操作INI文件的总结private static extern int GetPrivateProfileString(string section, string key, string defVal, Byte[] retVal, int size, string filePath);
关于C#操作INI文件的总结section:要读取的段落名
关于C#操作INI文件的总结key: 要读取的键
关于C#操作INI文件的总结defVal: 读取异常的情况下的缺省值
关于C#操作INI文件的总结retVal: 此参数类型不是string,而是Byte[]用于返回byte类型的section组或键值组。
关于C#操作INI文件的总结size: 值允许的大小
关于C#操作INI文件的总结filePath: INI文件的完整路径和文件名

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

//path为ini文件的物理路径

IniFile ini = new IniFile(path);

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

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

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

string[] sectionList;

ASCIIEncoding ascii = new ASCIIEncoding();

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

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

//编码所有key的string类型

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的基本上所有操作,当然这只是简单的举例,不是详细的实现,欢迎随时提出任何疑问和建议。