C# ini文件读写类

简介: VC中提供了API函数进行INI文件的读写操作,但是微软推出的C#编程语言中却没有相应的方法,下面是一个C# ini文件读写类,从网上收集的,很全,就是没有对section的改名功能,高手可以增加一个。
VC中提供了API函数进行INI文件的读写操作,但是微软推出的C#编程语言中却没有相应的方法,下面是一个C# ini文件读写类,
从网上收集的,很全,就是没有对section的改名功能,高手可以增加一个。
using System; using System.IO; using System.Runtime.InteropServices; using System.Text; using System.Collections; using System.Collections.Specialized; namespace wuyisky{   /**//**/   /**//// <summary>   /// IniFiles的类   /// </summary>   public class IniFiles   {     public string FileName; //INI文件名     //声明读写INI文件的API函数     [DllImport("kernel32")]     private static extern bool WritePrivateProfileString(string section, string key, string val, string filePath);     [DllImport("kernel32")]     private static extern int GetPrivateProfileString(string section, string key, string def, byte[] retVal, int size, string filePath);     //类的构造函数,传递INI文件名     public IniFiles(string AFileName)     {       // 判断文件是否存在       FileInfo fileInfo = new FileInfo(AFileName);       //Todo:搞清枚举的用法       if ((!fileInfo.Exists))       { //|| (FileAttributes.Directory in fileInfo.Attributes))         //文件不存在,建立文件         System.IO.StreamWriter sw = new System.IO.StreamWriter(AFileName, false, System.Text.Encoding.Default);         try         {           sw.Write("#表格配置档案");           sw.Close();         }         catch         {           throw (new ApplicationException("Ini文件不存在"));         }       }       //必须是完全路径,不能是相对路径       FileName = fileInfo.FullName;     }     //写INI文件     public void WriteString(string Section, string Ident, string Value)     {       if (!WritePrivateProfileString(Section, Ident, Value, FileName))       {           throw (new ApplicationException("写Ini文件出错"));       }     }     //读取INI文件指定     public string ReadString(string Section, string Ident, string Default)     {       Byte[] Buffer = new Byte[65535];       int bufLen = GetPrivateProfileString(Section, Ident, Default, Buffer, Buffer.GetUpperBound(0), FileName);       //必须设定0(系统默认的代码页)的编码方式,否则无法支持中文       string s = Encoding.GetEncoding(0).GetString(Buffer);       s = s.Substring(0, bufLen);       return s.Trim();     }     //读整数     public int ReadInteger(string Section, string Ident, int Default)     {       string intStr = ReadString(Section, Ident, Convert.ToString(Default));       try       {         return Convert.ToInt32(intStr);       }       catch (Exception ex)       {         Console.WriteLine(ex.Message);         return Default;       }     }     //写整数     public void WriteInteger(string Section, string Ident, int Value)     {       WriteString(Section, Ident, Value.ToString());     }     //读布尔     public bool ReadBool(string Section, string Ident, bool Default)     {       try       {         return Convert.ToBoolean(ReadString(Section, Ident, Convert.ToString(Default)));       }       catch (Exception ex)       {         Console.WriteLine(ex.Message);         return Default;       }     }     //写Bool     public void WriteBool(string Section, string Ident, bool Value)     {       WriteString(Section, Ident, Convert.ToString(Value));     }     //从Ini文件中,将指定的Section名称中的所有Ident添加到列表中     public void ReadSection(string Section, StringCollection Idents)     {       Byte[] Buffer = new Byte[16384];       //Idents.Clear();       int bufLen = GetPrivateProfileString(Section, null, null, Buffer, Buffer.GetUpperBound(0),        FileName);       //对Section进行解析       GetStringsFromBuffer(Buffer, bufLen, Idents);     }     private void GetStringsFromBuffer(Byte[] Buffer, int bufLen, StringCollection Strings)     {       Strings.Clear();       if (bufLen != 0)       {         int start = 0;         for (int i = 0; i < bufLen; i++)         {           if ((Buffer[i] == 0) && ((i - start) > 0))           {             String s = Encoding.GetEncoding(0).GetString(Buffer, start, i - start);             Strings.Add(s);             start = i + 1;           }         }       }     }     //从Ini文件中,读取所有的Sections的名称     public void ReadSections(StringCollection SectionList)     {       //Note:必须得用Bytes来实现,StringBuilder只能取到第一个Section       byte[] Buffer = new byte[65535];       int bufLen = 0;       bufLen = GetPrivateProfileString(null, null, null, Buffer,        Buffer.GetUpperBound(0), FileName);       GetStringsFromBuffer(Buffer, bufLen, SectionList);     }     //读取指定的Section的所有Value到列表中     public void ReadSectionValues(string Section, NameValueCollection Values)     {       StringCollection KeyList = new StringCollection();       ReadSection(Section, KeyList);       Values.Clear();       foreach (string key in KeyList)       {         Values.Add(key, ReadString(Section, key, ""));          }     }     /**/////读取指定的Section的所有Value到列表中,     //public void ReadSectionValues(string Section, NameValueCollection Values,char splitString)     //{  string sectionValue;     //  string[] sectionValueSplit;     //  StringCollection KeyList = new StringCollection();     //  ReadSection(Section, KeyList);     //  Values.Clear();     //  foreach (string key in KeyList)     //  {     //    sectionValue=ReadString(Section, key, "");     //    sectionValueSplit=sectionValue.Split(splitString);     //    Values.Add(key, sectionValueSplit[0].ToString(),sectionValueSplit[1].ToString());       //  }     //}     //清除某个Section     public void EraseSection(string Section)     {       //       if (!WritePrivateProfileString(Section, null, null, FileName))       {         throw (new ApplicationException("无法清除Ini文件中的Section"));       }     }     //删除某个Section下的键     public void DeleteKey(string Section, string Ident)     {       WritePrivateProfileString(Section, Ident, null, FileName);     }     //Note:对于Win9X,来说需要实现UpdateFile方法将缓冲中的数据写入文件     //在Win NT, 2000和XP上,都是直接写文件,没有缓冲,所以,无须实现UpdateFile     //执行完对Ini文件的修改之后,应该调用本方法更新缓冲区。     public void UpdateFile()     {       WritePrivateProfileString(null, null, null, FileName);     }     //检查某个Section下的某个键值是否存在     public bool ValueExists(string Section, string Ident)     {       //       StringCollection Idents = new StringCollection();       ReadSection(Section, Idents);       return Idents.IndexOf(Ident) > -1;     }     //确保资源的释放     ~IniFiles()     {       UpdateFile();     }   } }

 

目录
相关文章
|
7天前
|
存储 C# 索引
C# 一分钟浅谈:数组与集合类的基本操作
【9月更文挑战第1天】本文详细介绍了C#中数组和集合类的基本操作,包括创建、访问、遍历及常见问题的解决方法。数组适用于固定长度的数据存储,而集合类如`List<T>`则提供了动态扩展的能力。文章通过示例代码展示了如何处理索引越界、数组长度不可变及集合容量不足等问题,并提供了解决方案。掌握这些基础知识可使程序更加高效和清晰。
30 2
|
6天前
|
C# 数据安全/隐私保护
C# 一分钟浅谈:类与对象的概念理解
【9月更文挑战第2天】本文从零开始详细介绍了C#中的类与对象概念。类作为一种自定义数据类型,定义了对象的属性和方法;对象则是类的实例,拥有独立的状态。通过具体代码示例,如定义 `Person` 类及其实例化过程,帮助读者更好地理解和应用这两个核心概念。此外,还总结了常见的问题及解决方法,为编写高质量的面向对象程序奠定基础。
11 2
|
1月前
|
监控 安全 C#
使用C#如何监控选定文件夹中文件的变动情况?
使用C#如何监控选定文件夹中文件的变动情况?
89 19
|
28天前
|
编译器 C# Windows
C#基础:手动编译一个.cs源代码文件并生成.exe可执行文件
通过上述步骤,应该能够高效准确地编译C#源代码并生成相应的可执行文件。此外,这一过程强调了对命令行编译器的理解,这在调试和自动化编译流程中是非常重要的。
43 2
|
19天前
|
Java C# 索引
C# 面向对象编程(一)——类
C# 面向对象编程(一)——类
25 0
|
24天前
|
开发框架 .NET 编译器
C# 中的记录(record)类型和类(class)类型对比总结
C# 中的记录(record)类型和类(class)类型对比总结
|
25天前
|
C# 图形学 数据安全/隐私保护
Unity数据加密☀️ 二、使用Rider将C#代码生成DLL文件
Unity数据加密☀️ 二、使用Rider将C#代码生成DLL文件
|
25天前
|
C#
C# 写日志文件
C# 写日志文件
34 0
|
4月前
|
开发框架 前端开发 .NET
C#编程与Web开发
【4月更文挑战第21天】本文探讨了C#在Web开发中的应用,包括使用ASP.NET框架、MVC模式、Web API和Entity Framework。C#作为.NET框架的主要语言,结合这些工具,能创建动态、高效的Web应用。实际案例涉及企业级应用、电子商务和社交媒体平台。尽管面临竞争和挑战,但C#在Web开发领域的前景将持续拓展。
157 3
|
4月前
|
SQL 开发框架 安全
C#编程与多线程处理
【4月更文挑战第21天】探索C#多线程处理,提升程序性能与响应性。了解C#中的Thread、Task类及Async/Await关键字,掌握线程同步与安全,实践并发计算、网络服务及UI优化。跟随未来发展趋势,利用C#打造高效应用。
173 3