1 using System.Text;
2 using System.Runtime.InteropServices;
3 using System;
4
5 namespace Benson.INI读写
6 {
7 #region INI结构介绍
8 /**
9 INI文件其实是一种具有特定结构的文本文件,它的构成分为三部分,结构如下:
10 [Section1]
11 key 1 = value2
12 key 1 = value2
13 ……
14 [Section2]
15 key 1 = value1
16 key 2 = value2
17 ……
18
19 文件由若干个段落(section)组成,每个段落又分成若干个键(key)和值(value)。
20 */
21 #endregion
22
23 #region INI读写辅助类,采用WIN32API
24 #region WIN32API介绍
25 /*
26 Windows系统自带的Win32的API函数GetPrivateProfileString()和WritePrivateProfileString()分别实现了对INI文件的读写操作,他们位于kernel32.dll下。
27 但是令人遗憾的是C#所使用的.NET框架下的公共类库并没有提供直接操作INI文件的类,所以唯一比较理想的方法就是调用API函数。
28 然后,.Net框架下的类库是基于托管代码的,而API函数是基于非托管代码的,(在运行库的控制下执行的代码称作托管代码。相反,在运行库之外运行的代码称作非托管代码。)如何实现托管代码与非托管代码之间的操作呢?.Net框架的System.Runtime.InteropServices命名空间下提供各种各样支持COM interop及平台调用服务的成员,其中最重要的属性之一DllImportAttribute可以用来定义用于访问非托管API的平台调用方法,它提供了对从非托管DLL导出的函数进行调用所必需的信息。下面就来看一下如何实现C#与API函数的互操作。
29 读操作:
30 [DllImport("kernel32")]
31 private static extern int GetPrivateProfileString(string section, string key, string defVal, StringBuilder retVal, int size, string filePath);
32 section:要读取的段落名
33 key: 要读取的键
34 defVal: 读取异常的情况下的缺省值
35 retVal: key所对应的值,如果该key不存在则返回空值
36 size: 值允许的大小
37 filePath: INI文件的完整路径和文件名写操作:
38
39 写操作
40 [DllImport("kernel32")]
41 private static extern long WritePrivateProfileString(string section, string key, string val, string filePath);
42 section: 要写入的段落名
43 key: 要写入的键,如果该key存在则覆盖写入
44 val: key所对应的值
45 filePath: INI文件的完整路径和文件名
46 */
47 #endregion
48
49 public class INIManager
50 {
51 public string iniPath; //INI文件路径以及名称
52
53 #region DLL导入
54 [DllImport("kernel32")]
55 private static extern long WritePrivateProfileString(string section, string key, string val, string filePath);
56 [DllImport("kernel32")]
57 private static extern int GetPrivateProfileString(string section, string key, string def, StringBuilder retVal, int size, string filePath);
58 #endregion
59
60 #region 构造函数
61 /// <summary>
62 /// 构造方法
63 /// </summary>
64 /// <param name="INIPath">文件路径</param>
65 public INIManager(string INIPath)
66 {
67 iniPath = INIPath;
68 }
69
70 /// <summary>
71 /// 在不提供文件时候的构造方法
72 /// </summary>
73 public INIManager() //如果不提供INI文件的路径以及名称,则默认为当前的应用名称.ini
74 {
75 char[] charsToTrim = { '\"',' '};
76 string fileNameWithoutExtension = System.IO.Path.GetFileNameWithoutExtension(Environment.CommandLine.Trim(charsToTrim));
77 iniPath = Environment.CurrentDirectory+ "\\" +fileNameWithoutExtension + ".ini";
78 //Console.WriteLine(iniPath); //Test Example
79 }
80 #endregion
81
82 #region INI写入
83 /// <summary>
84 /// 写入INI文件,如果键,值存在则直接覆盖
85 /// </summary>
86 /// <param name="section">段落名称(如"SectionName"(无需双引号))</param>
87 /// <param name="key">键</param>
88 /// <param name="value">值</param>
89 public void IniWriteValue(string section, string key, string value)
90 {
91 WritePrivateProfileString(section, key, value, this.iniPath);
92 }
93
94 /// <summary>
95 /// 写入INI文件,默认Default段落
96 /// </summary>
97 /// <param name="Key">键</param>
98 /// <param name="Value">值</param>
99 public void IniWriteValue( string Key, string Value)
100 {
101 string Section = @"Default";
102 IniWriteValue(Section, Key, Value);
103 }
104 #endregion
105
106 #region INI读取
107 /// <summary>
108 /// 读出INI文件
109 /// </summary>
110 /// <param name="section">段落名称(如"SectionName"(无需双引号) )</param>
111 /// <param name="Key">键</param>
112 /// <returns>返回对应键的值</returns>
113 public string IniReadValue(string section, string Key)
114 {
115 StringBuilder temp = new StringBuilder(500);
116 int i = GetPrivateProfileString(section, Key, "", temp, 500, this.iniPath);
117 return temp.ToString();
118 }
119
120 /// <summary>
121 /// 读出INI文件,默认情况下从Default中读取
122 /// </summary>
123 /// <param name="Key">键</param>
124 /// <returns>返回对应键的值</returns>
125 public string IniReadValue(string Key)
126 {
127 string section = @"Default";
128 return IniReadValue(section, Key);
129 }
130
131 }
132 #endregion
133
134 #endregion
135
136 #region 测试用类
137 class Test
138 {
139 static void Main(string[] args)
140 {
141 INIManager imDriveC = new INIManager(@"c:\test.ini");
142 Console.WriteLine(imDriveC.IniReadValue("name1").Equals("").ToString()); //首先查看在文件不存在的情况下的是否有异常,异常读取到的值
143 imDriveC.IniWriteValue("name1", "carl");
144 Console.WriteLine(imDriveC.IniReadValue("Name1"));
145
146
147
148 INIManager im = new INIManager();
149 im.IniWriteValue("姓","Cai");
150 im.IniWriteValue("名", "Benson");
151
152 Console.WriteLine(im.IniReadValue("姓"));
153 Console.WriteLine(im.IniReadValue("cao"));
154 Console.ReadKey();
155 }
156 }
157 #endregion
158
159 }