0

0

C#INI文件读写 C#如何操作传统的INI配置文件

星降

星降

发布时间:2026-02-10 10:03:12

|

560人浏览过

|

来源于php中文网

原创

C#中INI文件无原生支持,Windows平台推荐P/Invoke调用GetPrivateProfileString/WritePrivateProfileString;跨平台可选IniParser库,但需注意大小写、BOM及并发安全问题。

c#ini文件读写 c#如何操作传统的ini配置文件

INI文件在C#里没有原生支持,得靠Windows API或第三方库

Windows平台下,GetPrivateProfileStringWritePrivateProfileString 是最直接的方案,但它们是Win32 API,需要P/Invoke调用。.NET本身(包括.NET Core/.NET 5+)不提供内置INI解析器——别指望ConfigurationBuilder加个.AddIniFile()就能用,它根本不支持INI格式。

如果你在跨平台项目里硬要用INI,得自己解析(比如按行分割、处理节名[Section]、键值对key=value),但要注意:注释(;#)、空行、引号包裹值、转义等细节很容易出错。

用P/Invoke调用Win32 API是最轻量、最兼容的做法

适用于Windows桌面应用(WinForms/WPF),且不需要引入额外NuGet包。关键点:

  • GetPrivateProfileString 返回的是实际读取的字符数,不是布尔值;若返回0,不一定失败——可能值为空字符串,得检查lpReturnedString首字节是否为\0
  • 路径必须是绝对路径,相对路径会被解释为相对于当前进程工作目录,而非EXE所在目录
  • 写入时若文件不存在,API会自动创建;但目录不存在则写入失败,不会自动建目录
  • 所有字符串参数必须是string(.NET会自动封送为LPCSTR),不要传StringBuilder给读取函数——除非你手动控制缓冲区大小

示例读取:

[DllImport("kernel32.dll", CharSet = CharSet.Ansi)]
private static extern uint GetPrivateProfileString(
    string lpAppName, string lpKeyName, string lpDefault,
    StringBuilder lpReturnedString, uint nSize, string lpFileName);

var sb = new StringBuilder(256);
GetPrivateProfileString("Database", "Server", "", sb, (uint)sb.Capacity, @"C:\app\config.ini");
string server = sb.ToString();

用IniParser NuGet包更安全、可跨平台,但要注意默认行为

IniParser(NuGet包名:ini-parser)是目前最成熟的托管INI库,支持.NET Standard 2.0+,能处理注释、多行值、Unicode、节继承等。但它默认把键名转成小写——如果你的INI里有URLurl两个键,会被当成重复键覆盖。

易森网络企业版
易森网络企业版

如果您是新用户,请直接将本程序的所有文件上传在任一文件夹下,Rewrite 目录下放置了伪静态规则和筛选器,可将规则添加进IIS,即可正常使用,不用进行任何设置;(可修改图片等)默认的管理员用户名、密码和验证码都是:yeesen系统默认关闭,请上传后登陆后台点击“核心管理”里操作如下:进入“配置管理”中的&ld

下载

解决方法:

  • 构造FileIniDataParser时传入new IniDataParser(new ParsingRules { CaseSensitive = true })
  • 读取后修改再保存,必须调用parser.WriteFile(path, data),不能只改data["Section"]["Key"]就完事——内存对象修改后不写回磁盘,等于没改
  • 它不自动处理BOM,UTF-8无BOM文件读写最稳;带BOM的文件可能被误判编码,导致乱码

别忽略INI的固有缺陷:它不适合复杂配置

INI没有嵌套结构、没有数组原生语法、不支持类型推断(全是字符串)、无法表达null或布尔真伪(得靠约定如Enabled=1)。如果你的配置项开始出现Item1_NameItem1_ValueItem2_Name……说明该换JSON或XML了。

另外,多个线程同时读写同一个INI文件极易损坏内容——Win32 API本身不加锁,IniParser也不做并发保护。真要并发访问,得自己加lock或用FileStreamFileShare.None做排他控制。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

435

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

543

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

317

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

79

2025.09.10

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

668

2023.08.02

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

243

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

663

2024.03.01

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1922

2024.04.01

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

153

2026.02.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
CSS教程
CSS教程

共754课时 | 29.8万人学习

【web前端】Node.js快速入门
【web前端】Node.js快速入门

共16课时 | 2万人学习

微信小程序开发之API篇
微信小程序开发之API篇

共15课时 | 1.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号