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

简介: 原文:关于C#操作INI文件的总结          INI文件其实是一种具有特定结构的文本文件,它的构成分为三部分,结构如下: [Section1]key 1 = value2key 1 = value2……[Section2]key 1 = value1key 2 = value2…… 文件由若干个段落(section)组成,每个段落又分成若干个键(key)和值(value)。
原文: 关于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函数的互操作。

读操作:

img_a6339ee3e57d1d52bc7d02b338e15a60.gif [DllImport( " kernel32 " )]
img_a6339ee3e57d1d52bc7d02b338e15a60.gif
private   static   extern   int  GetPrivateProfileString( string  section,  string  key,  string  defVal, StringBuilder retVal,  int  size,  string  filePath); 
img_a6339ee3e57d1d52bc7d02b338e15a60.gifsection:要读取的段落名
img_a6339ee3e57d1d52bc7d02b338e15a60.gifkey: 要读取的键
img_a6339ee3e57d1d52bc7d02b338e15a60.gifdefVal: 读取异常的情况下的缺省值
img_a6339ee3e57d1d52bc7d02b338e15a60.gifretVal: key所对应的值,如果该key不存在则返回空值
img_a6339ee3e57d1d52bc7d02b338e15a60.gifsize: 值允许的大小
img_a6339ee3e57d1d52bc7d02b338e15a60.giffilePath: INI文件的完整路径和文件名

写操作:

img_a6339ee3e57d1d52bc7d02b338e15a60.gif [DllImport( " kernel32 " )] 
img_a6339ee3e57d1d52bc7d02b338e15a60.gif
private   static   extern   long  WritePrivateProfileString( string  section,  string  key,  string  val,  string  filePath); 
img_a6339ee3e57d1d52bc7d02b338e15a60.gifsection: 要写入的段落名
img_a6339ee3e57d1d52bc7d02b338e15a60.gifkey: 要写入的键,如果该key存在则覆盖写入
img_a6339ee3e57d1d52bc7d02b338e15a60.gifval: key所对应的值
img_a6339ee3e57d1d52bc7d02b338e15a60.giffilePath: INI文件的完整路径和文件名

      

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

 1 img_a6339ee3e57d1d52bc7d02b338e15a60.gif using  System;
 2 img_a6339ee3e57d1d52bc7d02b338e15a60.gif using  System.Runtime.InteropServices; 
 3 img_a6339ee3e57d1d52bc7d02b338e15a60.gif using  System.Text; 
 4 img_a6339ee3e57d1d52bc7d02b338e15a60.gif
 5 img_a6339ee3e57d1d52bc7d02b338e15a60.gif namespace  IPVOD.Hotel.Remoting
 6 img_405b18b4b6584ae338e0f6ecaf736533.gifimg_1c53668bcee393edac0d7b3b3daff1ae.gif img_a76e9bb6ed00cf1c9c9f4ee2f04b558b.gif {
 7img_2887d91d0594ef8793c1db92b8a1d545.gifimg_7a2b9a960ee9a98bfd25d306d55009f8.gif    /**//// <summary>
 8img_33d02437d135341f0800e3d415312ae8.gif    /// INI文件的操作类
 9img_105a1e124122b2abcee4ea8e9f5108f3.gif    /// </summary>

10img_33d02437d135341f0800e3d415312ae8.gif    public class IniFile
11img_2887d91d0594ef8793c1db92b8a1d545.gifimg_7a2b9a960ee9a98bfd25d306d55009f8.gif    img_a76e9bb6ed00cf1c9c9f4ee2f04b558b.gif{
12img_33d02437d135341f0800e3d415312ae8.gif        public string Path;
13img_33d02437d135341f0800e3d415312ae8.gif
14img_33d02437d135341f0800e3d415312ae8.gif        public IniFile(string path)
15img_2887d91d0594ef8793c1db92b8a1d545.gifimg_7a2b9a960ee9a98bfd25d306d55009f8.gif        img_a76e9bb6ed00cf1c9c9f4ee2f04b558b.gif{
16img_33d02437d135341f0800e3d415312ae8.gif            this.Path = path;
17img_105a1e124122b2abcee4ea8e9f5108f3.gif        }

18img_33d02437d135341f0800e3d415312ae8.gif        
19img_7a2b9a960ee9a98bfd25d306d55009f8.gifimg_2887d91d0594ef8793c1db92b8a1d545.gif        声明读写INI文件的API函数#region 声明读写INI文件的API函数 
20img_33d02437d135341f0800e3d415312ae8.gif        [DllImport("kernel32")] 
21img_33d02437d135341f0800e3d415312ae8.gif        private static extern long WritePrivateProfileString(string section, string key, string val, string filePath); 
22img_33d02437d135341f0800e3d415312ae8.gif
23img_33d02437d135341f0800e3d415312ae8.gif        [DllImport("kernel32")]
24img_33d02437d135341f0800e3d415312ae8.gif        private static extern int GetPrivateProfileString(string section, string key, string defVal, StringBuilder retVal, int size, string filePath); 
25img_33d02437d135341f0800e3d415312ae8.gif
26img_33d02437d135341f0800e3d415312ae8.gif        [DllImport("kernel32")]
27img_33d02437d135341f0800e3d415312ae8.gif        private static extern int GetPrivateProfileString(string section, string key, string defVal, Byte[] retVal, int size, string filePath);
28img_105a1e124122b2abcee4ea8e9f5108f3.gif        #endregion

29img_33d02437d135341f0800e3d415312ae8.gif
30img_2887d91d0594ef8793c1db92b8a1d545.gifimg_7a2b9a960ee9a98bfd25d306d55009f8.gif        /**//// <summary>
31img_33d02437d135341f0800e3d415312ae8.gif        /// 写INI文件
32img_33d02437d135341f0800e3d415312ae8.gif        /// </summary>
33img_33d02437d135341f0800e3d415312ae8.gif        /// <param name="section">段落</param>
34img_33d02437d135341f0800e3d415312ae8.gif        /// <param name="key"></param>
35img_105a1e124122b2abcee4ea8e9f5108f3.gif        /// <param name="iValue"></param>

36img_33d02437d135341f0800e3d415312ae8.gif        public void IniWriteValue(string section, string key, string iValue) 
37img_2887d91d0594ef8793c1db92b8a1d545.gifimg_7a2b9a960ee9a98bfd25d306d55009f8.gif        img_a76e9bb6ed00cf1c9c9f4ee2f04b558b.gif{
38img_33d02437d135341f0800e3d415312ae8.gif            WritePrivateProfileString(section, key, iValue, this.Path);
39img_105a1e124122b2abcee4ea8e9f5108f3.gif        }

40img_33d02437d135341f0800e3d415312ae8.gif
41img_2887d91d0594ef8793c1db92b8a1d545.gifimg_7a2b9a960ee9a98bfd25d306d55009f8.gif        /**//// <summary>
42img_33d02437d135341f0800e3d415312ae8.gif        /// 读取INI文件
43img_33d02437d135341f0800e3d415312ae8.gif        /// </summary>
44img_33d02437d135341f0800e3d415312ae8.gif        /// <param name="section">段落</param>
45img_33d02437d135341f0800e3d415312ae8.gif        /// <param name="key"></param>
46img_105a1e124122b2abcee4ea8e9f5108f3.gif        /// <returns>返回的键值</returns>

47img_33d02437d135341f0800e3d415312ae8.gif        public string IniReadValue(string section, string key) 
48img_2887d91d0594ef8793c1db92b8a1d545.gifimg_7a2b9a960ee9a98bfd25d306d55009f8.gif        img_a76e9bb6ed00cf1c9c9f4ee2f04b558b.gif
49img_33d02437d135341f0800e3d415312ae8.gif            StringBuilder temp = new StringBuilder(255); 
50img_33d02437d135341f0800e3d415312ae8.gif
51img_33d02437d135341f0800e3d415312ae8.gif            int i = GetPrivateProfileString(section, key, "", temp, 255this.Path); 
52img_33d02437d135341f0800e3d415312ae8.gif            return temp.ToString();
53img_105a1e124122b2abcee4ea8e9f5108f3.gif        }

54img_33d02437d135341f0800e3d415312ae8.gif
55img_2887d91d0594ef8793c1db92b8a1d545.gifimg_7a2b9a960ee9a98bfd25d306d55009f8.gif        /**//// <summary>
56img_33d02437d135341f0800e3d415312ae8.gif        /// 读取INI文件
57img_33d02437d135341f0800e3d415312ae8.gif        /// </summary>
58img_33d02437d135341f0800e3d415312ae8.gif        /// <param name="Section">段,格式[]</param>
59img_33d02437d135341f0800e3d415312ae8.gif        /// <param name="Key"></param>
60img_105a1e124122b2abcee4ea8e9f5108f3.gif        /// <returns>返回byte类型的section组或键值组</returns>

61img_33d02437d135341f0800e3d415312ae8.gif        public byte[] IniReadValues(string section, string key)
62img_2887d91d0594ef8793c1db92b8a1d545.gifimg_7a2b9a960ee9a98bfd25d306d55009f8.gif        img_a76e9bb6ed00cf1c9c9f4ee2f04b558b.gif{
63img_33d02437d135341f0800e3d415312ae8.gif            byte[] temp = new byte[255];
64img_33d02437d135341f0800e3d415312ae8.gif
65img_33d02437d135341f0800e3d415312ae8.gif            int i = GetPrivateProfileString(section, key, "", temp, 255this.Path);
66img_33d02437d135341f0800e3d415312ae8.gif            return temp;
67img_105a1e124122b2abcee4ea8e9f5108f3.gif        }

68img_105a1e124122b2abcee4ea8e9f5108f3.gif    }

69img_05dd8d549cff04457a6366b0a7c9352a.gif}

70 img_a6339ee3e57d1d52bc7d02b338e15a60.gif
<?xml:namespace prefix="o" ns="urn:schemas-microsoft-com:office:office"?>

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

img_a6339ee3e57d1d52bc7d02b338e15a60.gif [DllImport( " kernel32 " )] 
img_a6339ee3e57d1d52bc7d02b338e15a60.gif
private   static   extern   int  GetPrivateProfileString( string  section,  string  key,  string  defVal, Byte[] retVal,  int  size,  string  filePath);
img_a6339ee3e57d1d52bc7d02b338e15a60.gifsection:要读取的段落名
img_a6339ee3e57d1d52bc7d02b338e15a60.gifkey: 要读取的键
img_a6339ee3e57d1d52bc7d02b338e15a60.gifdefVal: 读取异常的情况下的缺省值
img_a6339ee3e57d1d52bc7d02b338e15a60.gifretVal: 此参数类型不是string,而是Byte[]用于返回byte类型的section组或键值组。
img_a6339ee3e57d1d52bc7d02b338e15a60.gifsize: 值允许的大小
img_a6339ee3e57d1d52bc7d02b338e15a60.giffilePath: 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的基本上所有操作,当然这只是简单的举例,不是详细的实现,欢迎随时提出任何疑问和建议。

目录
相关文章
|
1月前
|
XML C# 数据格式
使用C#操作XML文件
使用C#操作XML文件
11 0
|
1月前
|
C#
C# 文件操作(全部) 追加、拷贝、删除、移动文件、创建目录
C# 文件操作(全部) 追加、拷贝、删除、移动文件、创建目录
23 0
|
3月前
|
C#
C#读取html文件
C#读取html文件
29 3
|
3月前
|
C# 开发者
C# 10.0中的文件范围命名空间:简化代码组织的新方式
【1月更文挑战第18天】C# 10.0引入了文件范围的命名空间,这是一种新的语法糖,用于更简洁地组织和管理代码。文件范围命名空间允许开发者在每个文件的基础上定义命名空间,而无需显式使用花括号包裹整个文件内容。本文将深入探讨文件范围命名空间的工作原理、使用场景以及它们为C#开发者带来的便利。
|
5月前
|
C#
Visual Studio C# CS0006 C# 未能找到元数据文件
Visual Studio C# CS0006 C# 未能找到元数据文件
66 0
Visual Studio C# CS0006 C# 未能找到元数据文件
|
6月前
|
开发框架 .NET C#
利用WinDbg分析C#程序产生的转储文件
利用WinDbg分析C#程序产生的转储文件
|
7天前
|
XML C# 数据格式
C# 解析XML文件
C# 解析XML文件
15 1
|
4月前
|
IDE C# 开发工具
C# | 多线程批量下载文件(创建N个线程同时批量下载文件,只需要几行代码而已)
批量下载文件时使用多线程可以有效缩短完成时间,本文将讲解如何使用C#+CodePlus扩展库快速完成多线程的文件下载。 大部分代码由IDE自动生成,需要我们自己编写的代码正好**10行**。也就是说,只需要10分钟,就可以手撸一个多线程的批量下载器。
88 0
C# | 多线程批量下载文件(创建N个线程同时批量下载文件,只需要几行代码而已)
|
1月前
|
安全 数据处理 C#
C# Post数据或文件到指定的服务器进行接收
C# Post数据或文件到指定的服务器进行接收
|
1月前
|
C# 开发工具 数据安全/隐私保护
C#实现基于Word保护性模板文件的修改
C#实现基于Word保护性模板文件的修改