LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

C# 讀寫 INI 文件的最簡方法

admin
2025年5月23日 12:2 本文熱度 98

一、前言

INI文件,全稱為Initialization File(初始化文件),是一種傳統(tǒng)的文本型配置文件格式,廣泛應(yīng)用于Windows操作系統(tǒng)及早期應(yīng)用程序中,用于存儲軟件的各項設(shè)置和參數(shù)。

盡管開發(fā)中XML、JSON或更現(xiàn)代的配置格式如YAML等逐漸占據(jù)主流,但I(xiàn)NI文件憑借其簡潔明了的結(jié)構(gòu)和易于人類閱讀與編輯的特點,在特定場景下仍然具有不可替代的價值。

本文將聚焦于C#語言環(huán)境下,介紹如何以最簡化的方式實現(xiàn)INI文件的讀寫操作。

二、INI文件基礎(chǔ)

INI文件采用鍵值對(key-value pairs)的形式組織數(shù)據(jù),并將其劃分為若干個邏輯段落(sections)。

其基本結(jié)構(gòu)如下:

; 注釋行(以分號開始)

[Section1]     ; 段落名,用方括號包圍
key1 = value1   ; 鍵值對,等號分隔鍵與值
key2 = value2

[Section2]
keyA = valueA
keyB = valueB

其中:

注釋:以分號(;)開頭的行被視為注釋,用于解釋文件中的設(shè)置。

段落(Section):用方括號([])包裹的名稱標(biāo)識一個特定的配置區(qū)域,用于分類相關(guān)設(shè)置。

鍵(Key):在每個段落內(nèi)定義的唯一標(biāo)識符,用于表示特定的配置項。

值(Value):與鍵關(guān)聯(lián)的數(shù)據(jù),可以是字符串、數(shù)字或其他簡單文本表示的信息。

三、C#讀寫INI文件的最簡方法

在C#中,雖然.NET框架并未直接提供對INI文件的內(nèi)置支持,但可以通過以下兩種簡便途徑實現(xiàn)INI文件的讀寫:

1、使用Microsoft.VisualBasic命名空間提供的API

盡管名為Visual Basic,但此命名空間中的類庫在C#中同樣可用。

其中包含了對INI文件操作的便捷方法,無需額外引入外部庫或編寫復(fù)雜的P/Invoke代碼。

以下是最簡示例:

using Microsoft.VisualBasic.FileIO;

// 讀取INI文件
public string ReadIniValue(string section, string key, string filePath)
{
    return IniParser.ReadKeyValue(filePath, section, key, "");
}

// 寫入INI文件
public void WriteIniValue(string section, string key, string valuestring filePath)
{
    IniParser.WriteKeyValue(filePath, section, key, value);
}

// 定義輔助類
internal static class IniParser
{
    [DllImport("kernel32")]
    private static extern int GetPrivateProfileString(string section, string key, string def, StringBuilder retVal, int size, string filePath);
    [DllImport("kernel32")]
    private static extern int WritePrivateProfileString(string section, string key, string val, string filePath);

    internal static string ReadKeyValue(string iniPath, string section, string key, string defaultValue)
    {
        const int MAX_BUFFER = 65535;
        var sb = new StringBuilder(MAX_BUFFER);
        GetPrivateProfileString(section, key, defaultValue, sb, MAX_BUFFER, iniPath);
        return sb.ToString();
    }

    internal static void WriteKeyValue(string iniPath, string section, string key, string value)
    {
        WritePrivateProfileString(section, key, value, iniPath);
    }
}

2、利用第三方庫

若希望避免直接調(diào)用Win32 API,或者尋求更豐富的功能和更好的錯誤處理,可以選用成熟的第三方庫,如IniFileParser或Nini等。

這些庫提供了面向?qū)ο蟮慕涌冢喕薎NI文件的操作。

以下是一個使用IniFileParser庫的簡例:

using IniParser;
using IniParser.Model;

// 讀取INI文件
public string ReadIniValue(string section, string key, string filePath)
{
    var parser = new FileIniDataParser();
    IniData data = parser.ReadFile(filePath);
    return data[section][key];
}

// 寫入INI文件
public void WriteIniValue(string section, string key, string valuestring filePath)
{
    var parser = new FileIniDataParser();
    IniData data = parser.ReadFile(filePath);
    data[section][key] = value;
    parser.WriteFile(filePath, data);
}

四、結(jié)語

盡管INI文件并非現(xiàn)代應(yīng)用程序首選的配置格式,但在特定需求下,尤其是對于輕量級、跨平臺要求不高的項目,其簡潔性仍使其成為一個可行的選擇。

C#開發(fā)可通過使用Microsoft.VisualBasic命名空間提供的API或第三方庫,以最簡化的代碼實現(xiàn)INI文件的讀寫操作。

這兩種方法均能有效滿足基本的INI文件處理需求,可根據(jù)項目的具體需求和偏好選擇合適的方法。

作者:DotNet開發(fā)跳槽

出處:mp.weixin.qq.com/s/NLt-C3wtPT2HFc39mlbQVA


該文章在 2025/5/23 12:02:31 編輯過
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點晴ERP是一款針對中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內(nèi)大量中小企業(yè)的青睞。
點晴PMS碼頭管理系統(tǒng)主要針對港口碼頭集裝箱與散貨日常運作、調(diào)度、堆場、車隊、財務(wù)費用、相關(guān)報表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點,圍繞調(diào)度、堆場作業(yè)而開發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點晴WMS倉儲管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質(zhì)期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務(wù)都免費,不限功能、不限時間、不限用戶的免費OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved

黄频国产免费高清视频,久久不卡精品中文字幕一区,激情五月天AV电影在线观看,欧美国产韩国日本一区二区
亚洲日韩欧美一区二区 | 日韩亚洲欧美大陆 | 亚洲中文高清乱码 | 亚洲视频在线香蕉 | 中文字幕亚洲视频 | 视频偷拍一区二区三区 |