ini 文件是文本文件,中间的数据格式一般为:
[Section1 Name]
KeyName1=value1
KeyName2=value2
...
[Section2 Name]
KeyName1=value1
KeyName2=value2
ini 文件可以分为几个 Section,每个 Section 的名称用 [] 括起来,在一个 Section 中,可以有很多的 Key,每一个 Key 可以有一个值并占用一行,格式是 Key=value
INI读写函数说明:
读操作:
[DllImport("kernel32")]
private static extern int GetPrivateProfileString(string section, string key, string defVal, StringBuilder retVal, int size, string filePath);
section:要读取的段落名
key: 要读取的键
defVal: 读取异常的情况下的缺省值
retVal: key所对应的值,如果该key不存在则返回空值
size: 值允许的大小
filePath: INI文件的完整路径和文件名
写操作:
[DllImport("kernel32")]
private static extern long WritePrivateProfileString(string section, string key, string val, string filePath);
section: 要写入的段落名
key: 要写入的键,如果该key存在则覆盖写入
val: key所对应的值
filePath: INI文件的完整路径和文件名
using System;
2using System.Runtime.InteropServices;
3using System.Text;
4
5namespace IPVOD.Hotel.Remoting
6{
7 /// <summary>
8 /// INI文件的操作类
9 /// </summary>
10 public class IniFile
11 {
12 public string Path;
13
14 public IniFile(string path)
15 {
16 this.Path = path;
17 }
18
19 #region 声明读写INI文件的API函数
20 [DllImport("kernel32")]
21 private static extern long WritePrivateProfileString(string section, string key, string val, string filePath);
22
23 [DllImport("kernel32")]
24 private static extern int GetPrivateProfileString(string section, string key, string defVal, StringBuilder retVal, int size, string filePath);
25
26 [DllImport("kernel32")]
27 private static extern int GetPrivateProfileString(string section, string key, string defVal, Byte[] retVal, int size, string filePath);
28 #endregion
29
30 /// <summary>
31 /// 写INI文件
32 /// </summary>
33 /// <param name="section">段落</param>
34 /// <param name="key">键</param>
35 /// <param name="iValue">值</param>
36 public void IniWriteValue(string section, string key, string iValue)
37 {
38 WritePrivateProfileString(section, key, iValue, this.Path);
39 }
40
41 /// <summary>
42 /// 读取INI文件
43 /// </summary>
44 /// <param name="section">段落</param>
45 /// <param name="key">键</param>
46 /// <returns>返回的键值</returns>
47 public string IniReadValue(string section, string key)
48 {
49 StringBuilder temp = new StringBuilder(255);
50
51 int i = GetPrivateProfileString(section, key, "", temp, 255, this.Path);
52 return temp.ToString();
53 }
54
55 /// <summary>
56 /// 读取INI文件
57 /// </summary>
58 /// <param name="Section">段,格式[]</param>
59 /// <param name="Key">键</param>
60 /// <returns>返回byte类型的section组或键值组</returns>
61 public byte[] IniReadValues(string section, string key)
62 {
63 byte[] temp = new byte[255];
64
65 int i = GetPrivateProfileString(section, key, "", temp, 255, this.Path);
66 return temp;
67 }
68 }
69}
下面看一下具体实例化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);