มีคลาสใด ๆ ใน. NET Framework ที่สามารถอ่าน / เขียนไฟล์. ini มาตรฐาน:
[Section]
<keyname>=<value>
...
Delphi มีTIniFile
องค์ประกอบและฉันต้องการที่จะรู้ว่ามีอะไรที่คล้ายกันสำหรับ C #?
มีคลาสใด ๆ ใน. NET Framework ที่สามารถอ่าน / เขียนไฟล์. ini มาตรฐาน:
[Section]
<keyname>=<value>
...
Delphi มีTIniFile
องค์ประกอบและฉันต้องการที่จะรู้ว่ามีอะไรที่คล้ายกันสำหรับ C #?
คำตอบ:
ผู้สร้างเฟรมเวิร์ก. NET ต้องการให้คุณใช้ไฟล์กำหนดค่าที่อิงกับ XML แทนที่จะเป็นไฟล์ INI ไม่เลยไม่มีกลไกในตัวสำหรับอ่าน
มีวิธีแก้ไขปัญหาของบุคคลที่สามอยู่
ประการแรกอ่านโพสต์บล็อก MSDN ในข้อ จำกัด ของ INI ไฟล์ ถ้ามันเหมาะสมกับความต้องการของคุณอ่านต่อ
นี่เป็นการใช้งานที่รัดกุมที่ฉันเขียนโดยใช้ Windows P / Invoke ดั้งเดิมดังนั้นจึงรองรับ Windows ทุกรุ่นที่ติดตั้ง. NET (เช่น Windows 98 - Windows 10) ฉันจะปล่อยมันในโดเมนสาธารณะ - คุณมีอิสระที่จะใช้ในเชิงพาณิชย์โดยไม่มีการระบุแหล่งที่มา
เพิ่มคลาสใหม่ที่เรียกว่าIniFile.cs
โครงการของคุณ:
using System.IO;
using System.Reflection;
using System.Runtime.InteropServices;
using System.Text;
// Change this to match your program's normal namespace
namespace MyProg
{
class IniFile // revision 11
{
string Path;
string EXE = Assembly.GetExecutingAssembly().GetName().Name;
[DllImport("kernel32", CharSet = CharSet.Unicode)]
static extern long WritePrivateProfileString(string Section, string Key, string Value, string FilePath);
[DllImport("kernel32", CharSet = CharSet.Unicode)]
static extern int GetPrivateProfileString(string Section, string Key, string Default, StringBuilder RetVal, int Size, string FilePath);
public IniFile(string IniPath = null)
{
Path = new FileInfo(IniPath ?? EXE + ".ini").FullName;
}
public string Read(string Key, string Section = null)
{
var RetVal = new StringBuilder(255);
GetPrivateProfileString(Section ?? EXE, Key, "", RetVal, 255, Path);
return RetVal.ToString();
}
public void Write(string Key, string Value, string Section = null)
{
WritePrivateProfileString(Section ?? EXE, Key, Value, Path);
}
public void DeleteKey(string Key, string Section = null)
{
Write(Key, null, Section ?? EXE);
}
public void DeleteSection(string Section = null)
{
Write(null, null, Section ?? EXE);
}
public bool KeyExists(string Key, string Section = null)
{
return Read(Key, Section).Length > 0;
}
}
}
เปิดไฟล์ INI ด้วยวิธีใดวิธีหนึ่งจาก 3 วิธีต่อไปนี้:
// Creates or loads an INI file in the same directory as your executable
// named EXE.ini (where EXE is the name of your executable)
var MyIni = new IniFile();
// Or specify a specific name in the current dir
var MyIni = new IniFile("Settings.ini");
// Or specify a specific name in a specific dir
var MyIni = new IniFile(@"C:\Settings.ini");
คุณสามารถเขียนค่าบางอย่างเช่น:
MyIni.Write("DefaultVolume", "100");
MyIni.Write("HomePage", "http://www.google.com");
วิธีสร้างไฟล์เช่นนี้:
[MyProg]
DefaultVolume=100
HomePage=http://www.google.com
หากต้องการอ่านค่าจากไฟล์ INI:
var DefaultVolume = IniFile.Read("DefaultVolume");
var HomePage = IniFile.Read("HomePage");
คุณสามารถตั้งค่า[Section]
:
MyIni.Write("DefaultVolume", "100", "Audio");
MyIni.Write("HomePage", "http://www.google.com", "Web");
วิธีสร้างไฟล์เช่นนี้:
[Audio]
DefaultVolume=100
[Web]
HomePage=http://www.google.com
คุณสามารถตรวจสอบการมีอยู่ของคีย์ดังนี้:
if(!MyIni.KeyExists("DefaultVolume", "Audio"))
{
MyIni.Write("DefaultVolume", "100", "Audio");
}
คุณสามารถลบรหัสได้โดยทำดังนี้
MyIni.DeleteKey("DefaultVolume", "Audio");
คุณสามารถลบทั้งส่วน (รวมถึงปุ่มทั้งหมด) ดังนี้:
MyIni.DeleteSection("Web");
โปรดแสดงความคิดเห็นด้วยการปรับปรุงใด ๆ !
GetSections()
วิธี
Path.GetFullPath(IniPath ?? Path.ChangeExtension(Application.ExecutablePath, ".ini"))
ของชอบ
บทความเกี่ยวกับ CodeProject " คลาสจัดการไฟล์ INI โดยใช้ C # " นี้จะช่วยได้
ผู้เขียนสร้างคลาส C # "Ini" ซึ่งแสดงถึงสองฟังก์ชันจาก KERNEL32.dll ฟังก์ชั่นเหล่านี้คือ: และWritePrivateProfileString
GetPrivateProfileString
คุณจะต้องสอง namespaces: และSystem.Runtime.InteropServices
System.Text
ขั้นตอนในการใช้คลาส Ini
ในคำนิยามโครงการเนมสเปซของคุณเพิ่ม
using INI;
สร้าง INIFile เช่นนี้
INIFile ini = new INIFile("C:\\test.ini");
ใช้IniWriteValue
เพื่อเขียนค่าใหม่ไปยังคีย์เฉพาะในส่วนหรือใช้IniReadValue
เพื่ออ่านค่าจากคีย์ในส่วนเฉพาะ
หมายเหตุ: ถ้าคุณกำลังเริ่มต้นจากรอยขีดข่วนคุณสามารถอ่านบทความ MSDN : วิธีการ: เพิ่มการประยุกต์ใช้แฟ้มการกำหนดค่า C # โครงการ เป็นวิธีที่ดีกว่าสำหรับการกำหนดค่าแอปพลิเคชันของคุณ
ฉันพบว่าการใช้งานที่เรียบง่ายนี้:
http://bytes.com/topic/net/insights/797169-reading-parsing-ini-file-c
ทำงานได้ดีสำหรับสิ่งที่ฉันต้องการ
นี่คือวิธีที่คุณใช้:
public class TestParser
{
public static void Main()
{
IniParser parser = new IniParser(@"C:\test.ini");
String newMessage;
newMessage = parser.GetSetting("appsettings", "msgpart1");
newMessage += parser.GetSetting("appsettings", "msgpart2");
newMessage += parser.GetSetting("punctuation", "ex");
//Returns "Hello World!"
Console.WriteLine(newMessage);
Console.ReadLine();
}
}
นี่คือรหัส:
using System;
using System.IO;
using System.Collections;
public class IniParser
{
private Hashtable keyPairs = new Hashtable();
private String iniFilePath;
private struct SectionPair
{
public String Section;
public String Key;
}
/// <summary>
/// Opens the INI file at the given path and enumerates the values in the IniParser.
/// </summary>
/// <param name="iniPath">Full path to INI file.</param>
public IniParser(String iniPath)
{
TextReader iniFile = null;
String strLine = null;
String currentRoot = null;
String[] keyPair = null;
iniFilePath = iniPath;
if (File.Exists(iniPath))
{
try
{
iniFile = new StreamReader(iniPath);
strLine = iniFile.ReadLine();
while (strLine != null)
{
strLine = strLine.Trim().ToUpper();
if (strLine != "")
{
if (strLine.StartsWith("[") && strLine.EndsWith("]"))
{
currentRoot = strLine.Substring(1, strLine.Length - 2);
}
else
{
keyPair = strLine.Split(new char[] { '=' }, 2);
SectionPair sectionPair;
String value = null;
if (currentRoot == null)
currentRoot = "ROOT";
sectionPair.Section = currentRoot;
sectionPair.Key = keyPair[0];
if (keyPair.Length > 1)
value = keyPair[1];
keyPairs.Add(sectionPair, value);
}
}
strLine = iniFile.ReadLine();
}
}
catch (Exception ex)
{
throw ex;
}
finally
{
if (iniFile != null)
iniFile.Close();
}
}
else
throw new FileNotFoundException("Unable to locate " + iniPath);
}
/// <summary>
/// Returns the value for the given section, key pair.
/// </summary>
/// <param name="sectionName">Section name.</param>
/// <param name="settingName">Key name.</param>
public String GetSetting(String sectionName, String settingName)
{
SectionPair sectionPair;
sectionPair.Section = sectionName.ToUpper();
sectionPair.Key = settingName.ToUpper();
return (String)keyPairs[sectionPair];
}
/// <summary>
/// Enumerates all lines for given section.
/// </summary>
/// <param name="sectionName">Section to enum.</param>
public String[] EnumSection(String sectionName)
{
ArrayList tmpArray = new ArrayList();
foreach (SectionPair pair in keyPairs.Keys)
{
if (pair.Section == sectionName.ToUpper())
tmpArray.Add(pair.Key);
}
return (String[])tmpArray.ToArray(typeof(String));
}
/// <summary>
/// Adds or replaces a setting to the table to be saved.
/// </summary>
/// <param name="sectionName">Section to add under.</param>
/// <param name="settingName">Key name to add.</param>
/// <param name="settingValue">Value of key.</param>
public void AddSetting(String sectionName, String settingName, String settingValue)
{
SectionPair sectionPair;
sectionPair.Section = sectionName.ToUpper();
sectionPair.Key = settingName.ToUpper();
if (keyPairs.ContainsKey(sectionPair))
keyPairs.Remove(sectionPair);
keyPairs.Add(sectionPair, settingValue);
}
/// <summary>
/// Adds or replaces a setting to the table to be saved with a null value.
/// </summary>
/// <param name="sectionName">Section to add under.</param>
/// <param name="settingName">Key name to add.</param>
public void AddSetting(String sectionName, String settingName)
{
AddSetting(sectionName, settingName, null);
}
/// <summary>
/// Remove a setting.
/// </summary>
/// <param name="sectionName">Section to add under.</param>
/// <param name="settingName">Key name to add.</param>
public void DeleteSetting(String sectionName, String settingName)
{
SectionPair sectionPair;
sectionPair.Section = sectionName.ToUpper();
sectionPair.Key = settingName.ToUpper();
if (keyPairs.ContainsKey(sectionPair))
keyPairs.Remove(sectionPair);
}
/// <summary>
/// Save settings to new file.
/// </summary>
/// <param name="newFilePath">New file path.</param>
public void SaveSettings(String newFilePath)
{
ArrayList sections = new ArrayList();
String tmpValue = "";
String strToSave = "";
foreach (SectionPair sectionPair in keyPairs.Keys)
{
if (!sections.Contains(sectionPair.Section))
sections.Add(sectionPair.Section);
}
foreach (String section in sections)
{
strToSave += ("[" + section + "]\r\n");
foreach (SectionPair sectionPair in keyPairs.Keys)
{
if (sectionPair.Section == section)
{
tmpValue = (String)keyPairs[sectionPair];
if (tmpValue != null)
tmpValue = "=" + tmpValue;
strToSave += (sectionPair.Key + tmpValue + "\r\n");
}
}
strToSave += "\r\n";
}
try
{
TextWriter tw = new StreamWriter(newFilePath);
tw.Write(strToSave);
tw.Close();
}
catch (Exception ex)
{
throw ex;
}
}
/// <summary>
/// Save settings back to ini file.
/// </summary>
public void SaveSettings()
{
SaveSettings(iniFilePath);
}
}
รหัสในคำตอบของ joerage เป็นแรงบันดาลใจ
น่าเสียดายที่มันเปลี่ยนปลอกตัวละครของปุ่มและไม่จัดการกับความคิดเห็น ดังนั้นฉันจึงเขียนสิ่งที่ควรจะแข็งแกร่งพอที่จะอ่าน (เฉพาะ) ไฟล์ INI ที่สกปรกมากและอนุญาตให้ดึงกุญแจได้เหมือนเดิม
มันใช้บาง LINQ, พจนานุกรมสตริงกรณีตายที่ไม่สำคัญกรณีเพื่อเก็บส่วนคีย์และค่าและอ่านไฟล์ในครั้งเดียว
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
class IniReader
{
Dictionary<string, Dictionary<string, string>> ini = new Dictionary<string, Dictionary<string, string>>(StringComparer.InvariantCultureIgnoreCase);
public IniReader(string file)
{
var txt = File.ReadAllText(file);
Dictionary<string, string> currentSection = new Dictionary<string, string>(StringComparer.InvariantCultureIgnoreCase);
ini[""] = currentSection;
foreach(var line in txt.Split(new[]{"\n"}, StringSplitOptions.RemoveEmptyEntries)
.Where(t => !string.IsNullOrWhiteSpace(t))
.Select(t => t.Trim()))
{
if (line.StartsWith(";"))
continue;
if (line.StartsWith("[") && line.EndsWith("]"))
{
currentSection = new Dictionary<string, string>(StringComparer.InvariantCultureIgnoreCase);
ini[line.Substring(1, line.LastIndexOf("]") - 1)] = currentSection;
continue;
}
var idx = line.IndexOf("=");
if (idx == -1)
currentSection[line] = "";
else
currentSection[line.Substring(0, idx)] = line.Substring(idx + 1);
}
}
public string GetValue(string key)
{
return GetValue(key, "", "");
}
public string GetValue(string key, string section)
{
return GetValue(key, section, "");
}
public string GetValue(string key, string section, string @default)
{
if (!ini.ContainsKey(section))
return @default;
if (!ini[section].ContainsKey(key))
return @default;
return ini[section][key];
}
public string[] GetKeys(string section)
{
if (!ini.ContainsKey(section))
return new string[0];
return ini[section].Keys.ToArray();
}
public string[] GetSections()
{
return ini.Keys.Where(t => t != "").ToArray();
}
}
catch (Exception ex) { throw ex; }
ในนั้น
ฉันต้องการแนะนำไลบรารี IniParser ที่ฉันสร้างขึ้นอย่างสมบูรณ์ใน c # ดังนั้นจึงไม่มีการอ้างอิงในระบบปฏิบัติการใด ๆ ซึ่งทำให้เข้ากันได้กับ Mono Open Source พร้อมสิทธิ์ใช้งานแบบ MIT เพื่อให้สามารถใช้ในรหัสใดก็ได้
คุณสามารถตรวจสอบแหล่งที่มาใน GitHubและมันยังมีอยู่ในแพ็คเกจ NuGet
มันสามารถกำหนดค่าได้อย่างมากและใช้งานง่ายมาก
ขออภัยสำหรับปลั๊กที่ไร้ยางอาย แต่ฉันหวังว่าจะเป็นประโยชน์สำหรับทุกคนที่ได้รับคำตอบนี้อีกครั้ง
หากคุณต้องการเพียงการเข้าถึงแบบอ่านและไม่เขียนการเข้าถึงและคุณกำลังใช้Microsoft.Extensions.Confiuration
(มาพร้อมกับค่าเริ่มต้นด้วย ASP.NET Core แต่ทำงานกับโปรแกรมปกติด้วย) คุณสามารถใช้แพ็คเกจ NuGet Microsoft.Extensions.Configuration.Ini
เพื่อนำเข้าไฟล์ ini ในการตั้งค่าการกำหนดค่าของคุณ
public Startup(IHostingEnvironment env)
{
var builder = new ConfigurationBuilder()
.SetBasePath(env.ContentRootPath)
.AddIniFile("SomeConfig.ini", optional: false);
Configuration = builder.Build();
}
Configuration["keyname"]
โดยปกติเมื่อคุณสร้างแอปพลิเคชันโดยใช้ C # และ. NET Framework คุณจะไม่ใช้ไฟล์ INI เป็นเรื่องปกติที่จะจัดเก็บการตั้งค่าในไฟล์กำหนดค่า XML หรือในรีจิสตรี อย่างไรก็ตามหากซอฟต์แวร์ของคุณใช้การตั้งค่าร่วมกับแอปพลิเคชันแบบดั้งเดิมอาจเป็นการง่ายกว่าที่จะใช้ไฟล์การกำหนดค่าแทนที่จะทำซ้ำข้อมูลในที่อื่น
. NET Framework ไม่รองรับการใช้ไฟล์ INI โดยตรง อย่างไรก็ตามคุณสามารถใช้ฟังก์ชัน Windows API กับ Platform Invocation Services (P / Invoke) เพื่อเขียนและอ่านจากไฟล์ ในลิงค์นี้เราสร้างคลาสที่แทนไฟล์ INI และใช้ฟังก์ชั่น Windows API เพื่อจัดการมัน กรุณาไปที่ลิงค์ต่อไปนี้
หากคุณต้องการเพียงผู้อ่านอย่างง่ายที่ไม่มีส่วนใด ๆ และ dll ที่อื่น ๆ ที่นี่เป็นวิธีแก้ปัญหาที่ง่าย:
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace Tool
{
public class Config
{
Dictionary <string, string> values;
public Config (string path)
{
values = File.ReadLines(path)
.Where(line => (!String.IsNullOrWhiteSpace(line) && !line.StartsWith("#")))
.Select(line => line.Split(new char[] { '=' }, 2, 0))
.ToDictionary(parts => parts[0].Trim(), parts => parts.Length>1?parts[1].Trim():null);
}
public string Value (string name, string value=null)
{
if (values!=null && values.ContainsKey(name))
{
return values[name];
}
return value;
}
}
}
ตัวอย่างการใช้งาน:
file = new Tool.Config (Path.GetDirectoryName(System.Reflection.Assembly.GetExecutingAssembly().Location) + "\\config.ini");
command = file.Value ("command");
action = file.Value ("action");
string value;
//second parameter is default value if no key found with this name
value = file.Value("debug","true");
this.debug = (value.ToLower()=="true" || value== "1");
value = file.Value("plain", "false");
this.plain = (value.ToLower() == "true" || value == "1");
กำหนดค่าเนื้อหาไฟล์ในขณะเดียวกัน (ตามที่คุณเห็นสนับสนุนสัญลักษณ์ # สำหรับความคิดเห็นบรรทัด):
#command to run
command = php
#default script
action = index.php
#debug mode
#debug = true
#plain text mode
#plain = false
#icon = favico.ico
ลองวิธีนี้:
public static Dictionary<string, string> ParseIniDataWithSections(string[] iniData)
{
var dict = new Dictionary<string, string>();
var rows = iniData.Where(t =>
!String.IsNullOrEmpty(t.Trim()) && !t.StartsWith(";") && (t.Contains('[') || t.Contains('=')));
if (rows == null || rows.Count() == 0) return dict;
string section = "";
foreach (string row in rows)
{
string rw = row.TrimStart();
if (rw.StartsWith("["))
section = rw.TrimStart('[').TrimEnd(']');
else
{
int index = rw.IndexOf('=');
dict[section + "-" + rw.Substring(0, index).Trim()] = rw.Substring(index+1).Trim().Trim('"');
}
}
return dict;
}
มันสร้างพจนานุกรมที่สำคัญคือ "-" คุณสามารถโหลดได้ดังนี้:
var dict = ParseIniDataWithSections(File.ReadAllLines(fileName));
PeanutButter.INIเป็นคลาส Nuget ที่ทำแพ็กเกจสำหรับการจัดการไฟล์ INI รองรับการอ่าน / เขียนรวมถึงความคิดเห็น - ความคิดเห็นของคุณจะถูกเก็บไว้ในการเขียน ดูเหมือนว่าจะเป็นที่นิยมพอสมควรมีการทดสอบและใช้งานง่าย นอกจากนี้ยังฟรีและโอเพ่นซอร์สทั้งหมด
คำเตือน: ฉันเป็นผู้เขียนของ PeanutButter.INI
ฉันมาสายเพื่อเข้าร่วมปาร์ตี้ แต่ฉันมีปัญหาเดียวกันในวันนี้และฉันได้เขียนการใช้งานต่อไปนี้:
using System.Text.RegularExpressions;
static bool match(this string str, string pat, out Match m) =>
(m = Regex.Match(str, pat, RegexOptions.IgnoreCase)).Success;
static void Main()
{
Dictionary<string, Dictionary<string, string>> ini = new Dictionary<string, Dictionary<string, string>>();
string section = "";
foreach (string line in File.ReadAllLines(.........)) // read from file
{
string ln = (line.Contains('#') ? line.Remove(line.IndexOf('#')) : line).Trim();
if (ln.match(@"^[ \t]*\[(?<sec>[\w\-]+)\]", out Match m))
section = m.Groups["sec"].ToString();
else if (ln.match(@"^[ \t]*(?<prop>[\w\-]+)\=(?<val>.*)", out m))
{
if (!ini.ContainsKey(section))
ini[section] = new Dictionary<string, string>();
ini[section][m.Groups["prop"].ToString()] = m.Groups["val"].ToString();
}
}
// access the ini file as follows:
string content = ini["section"]["property"];
}
จะต้องมีการตั้งข้อสังเกตว่าการใช้งานนี้ไม่ได้จัดการส่วนหรือคุณสมบัติที่ไม่พบ เพื่อให้บรรลุสิ่งนี้คุณควรขยายDictionary<,>
-class เพื่อจัดการกับคีย์ที่ไม่มีส่วน
เป็นอันดับตัวอย่างของDictionary<string, Dictionary<string, string>>
ไปยัง.ini
แฟ้ม: ผมใช้รหัสต่อไปนี้:
string targetpath = .........;
Dictionary<string, Dictionary<string, string>> ini = ........;
StringBuilder sb = new StringBuilder();
foreach (string section in ini.Keys)
{
sb.AppendLine($"[{section}]");
foreach (string property in ini[section].Keys)
sb.AppendLine($"{property}={ini[section][property]");
}
File.WriteAllText(targetpath, sb.ToString());
มี Ini Parser อยู่ในCommonLibrary.NET
สิ่งนี้มีการโอเวอร์โหลดที่สะดวกมากสำหรับการรับส่วน / ค่าและมีน้ำหนักเบา
นี่คือเวอร์ชันของฉันที่ใช้นิพจน์ทั่วไป รหัสนี้อนุมานว่าแต่ละชื่อส่วนนั้นมีความเป็นเอกลักษณ์ - แต่นี่ไม่เป็นความจริง - มันเหมาะสมที่จะแทนที่ Dictionary ด้วย List ฟังก์ชั่นนี้รองรับการแสดงความคิดเห็นไฟล์. ini เริ่มจาก ';' ตัวละคร ส่วนเริ่มต้นตามปกติ [ส่วน] และคู่ค่าคีย์ก็มาตามปกติ "key = value" สมมติฐานเช่นเดียวกับส่วน - ชื่อคีย์ไม่ซ้ำกัน
/// <summary>
/// Loads .ini file into dictionary.
/// </summary>
public static Dictionary<String, Dictionary<String, String>> loadIni(String file)
{
Dictionary<String, Dictionary<String, String>> d = new Dictionary<string, Dictionary<string, string>>();
String ini = File.ReadAllText(file);
// Remove comments, preserve linefeeds, if end-user needs to count line number.
ini = Regex.Replace(ini, @"^\s*;.*$", "", RegexOptions.Multiline);
// Pick up all lines from first section to another section
foreach (Match m in Regex.Matches(ini, "(^|[\r\n])\\[([^\r\n]*)\\][\r\n]+(.*?)(\\[([^\r\n]*)\\][\r\n]+|$)", RegexOptions.Singleline))
{
String sectionName = m.Groups[2].Value;
Dictionary<String, String> lines = new Dictionary<String, String>();
// Pick up "key = value" kind of syntax.
foreach (Match l in Regex.Matches(ini, @"^\s*(.*?)\s*=\s*(.*?)\s*$", RegexOptions.Multiline))
{
String key = l.Groups[1].Value;
String value = l.Groups[2].Value;
// Open up quotation if any.
value = Regex.Replace(value, "^\"(.*)\"$", "$1");
if (!lines.ContainsKey(key))
lines[key] = value;
}
if (!d.ContainsKey(sectionName))
d[sectionName] = lines;
}
return d;
}
นี่คือชั้นเรียนของฉันทำงานเหมือนมีเสน่ห์:
public static class IniFileManager
{
[DllImport("kernel32")]
private static extern long WritePrivateProfileString(string section,
string key, string val, string filePath);
[DllImport("kernel32")]
private static extern int GetPrivateProfileString(string section,
string key, string def, StringBuilder retVal,
int size, string filePath);
[DllImport("kernel32.dll")]
private static extern int GetPrivateProfileSection(string lpAppName,
byte[] lpszReturnBuffer, int nSize, string lpFileName);
/// <summary>
/// Write Data to the INI File
/// </summary>
/// <PARAM name="Section"></PARAM>
/// Section name
/// <PARAM name="Key"></PARAM>
/// Key Name
/// <PARAM name="Value"></PARAM>
/// Value Name
public static void IniWriteValue(string sPath,string Section, string Key, string Value)
{
WritePrivateProfileString(Section, Key, Value, sPath);
}
/// <summary>
/// Read Data Value From the Ini File
/// </summary>
/// <PARAM name="Section"></PARAM>
/// <PARAM name="Key"></PARAM>
/// <PARAM name="Path"></PARAM>
/// <returns></returns>
public static string IniReadValue(string sPath,string Section, string Key)
{
StringBuilder temp = new StringBuilder(255);
int i = GetPrivateProfileString(Section, Key, "", temp,
255, sPath);
return temp.ToString();
}
}
การใช้งานเป็น obviouse เนื่องจากเป็นคลาสแบบสแตติกเพียงเรียก IniFileManager.IniWriteValue เพื่ออ่านส่วนหรือ IniFileManager.IniReadValue เพื่ออ่านส่วน
คุณควรอ่านและเขียนข้อมูลจากไฟล์ xml เนื่องจากคุณสามารถบันทึกออบเจ็กต์ทั้งหมดไปยัง xml และคุณยังสามารถเติมออบเจ็กต์จาก xml ที่บันทึกไว้ได้ มันจะดีกว่าง่ายต่อการจัดการวัตถุ
นี่คือวิธีการ: เขียนข้อมูลวัตถุไปยังไฟล์ XML: https://msdn.microsoft.com/en-us/library/ms172873.aspx อ่านข้อมูลวัตถุจากไฟล์ XML: https://msdn.microsoft co.th / en-US / ห้องสมุด / ms172872.aspx