INI-failid on tekstipõhised failid, mida kasutatakse rakenduse konfiguratsiooniandmete salvestamiseks.
Kuigi Windows soovitab rakendusspetsiifiliste konfiguratsiooniandmete salvestamiseks kasutada Windowsi registrit; paljudel juhtudel leiate, et INI-failid pakuvad programmile kiiremat juurdepääsu oma sätetele. Windows ise kasutab isegi INI-faile; desktop.ini ja boot.ini olles vaid kaks näidet.
INI-failide oleku salvestamise mehhanismina on lihtne kasutada vormi suuruse ja asukoha salvestamist, kui soovite, et vorm ilmuks uuesti oma eelmisse kohta. Selle asemel, et otsida läbi terviku teabe andmebaas suuruse või asukoha leidmiseks kasutatakse selle asemel INI-faili.
INI failivorming
Lähtestamis- või konfiguratsiooniseadete fail (.INI) on tekstifail, mille piirarv on 64 KB, jagatuna lõikudeks, millest igaüks sisaldab null või enam klahvi. Iga klahv sisaldab null või enam väärtust.
Siin on näide:
[Jaotise nimi]
võtmenimi1 = väärtus
; kommentaar
võtmenimi2 = väärtus
Sektsioonide nimed on sulgudes sulgudes ja need peavad algama rea alguses. Jaotiste ja võtmete nimed ei ole tõstutundlikud (täht ei oma tähtsust) ega tohi sisaldada tühikuid.
võtme nimi järgneb võrdusmärk ("="), mis on vajadusel ümbritsetud eraldusmärkidega, mida eiratakse.Kui sama jaotis ilmub samas failis rohkem kui üks kord või kui sama võti ilmub samas jaos rohkem kui üks kord, siis loetakse viimast.
Võti võib sisaldada nöör, täisarv või loogilineväärtus.
Delphi IDE kasutab paljudel juhtudel INI failivormingut. Näiteks, .DSK-failid (töölaua sätted) kasutab INI-vormingut.
TIniFile klass
Delphi pakub TIniFile klass, kuulutatud inifiles.pas üksus koos meetoditega INI failide väärtuste salvestamiseks ja hankimiseks.
Enne TIniFile-meetoditega töötamist peate looma klassi eksemplari:
kasutab inifiles;
...
var
IniFile: TIniFile;
alustada
IniFile: = TIniFile. Loo ('myapp.ini');
Ülaltoodud kood loob IniFile'i objekti ja omistab 'myapp.ini' klassi ainsale omadusele - Atribuut FileName —Kasutatakse kasutatava INI-faili nime täpsustamiseks.
Eespool kirjutatud kood otsib koodi myapp.ini faili \ Windows kataloog. Parem viis rakenduse andmete salvestamiseks on rakenduse kaustas - lihtsalt määrake faili jaoks täielik failinimi Loo meetod:
// asetage INI rakenduste kausta,
// las sellel on rakenduse nimi
// ja 'ini' laiendamiseks:
iniFile: = TIniFile. Loo (ChangeFileExt (rakendus. ExeName, '. Ini'));
Lugemine INI-st
TIniFile klassis on mitu "loetud" meetodit. ReadString loeb a stringi väärtus võtmest, ReadInteger. Nupult numbri lugemiseks kasutatakse funktsiooni ReadFloat jms. Kõigil "loetud" meetoditel on vaikeväärtus, mida saab kasutada, kui kirjet pole.
Näiteks kuulutatakse ReadString järgmiselt:
funktsiooni ReadString (const Jaotis, identiteet, vaikimisi: keelpill): keelpill; alistada;
Kirjutage INI-le
TIniFile-l on iga lugemismeetodi jaoks vastav kirjutamismeetod. Need on WriteString, WriteBool, WriteInteger jne.
Näiteks kui soovime, et programm mäletaks viimase inimese nime, kes seda kasutas, millal see oli ja millised olid peamised vormi koordinaadid, võiksime luua lõigu nimega Kasutajad, märksõna nimega Viimane, Kuupäev teabe jälgimiseks ja jaotis nimega Paigutamine klahvidega Ülaosa, Vasak, Laiusja Kõrgus.
projekt1.ini
[Kasutaja]
Viimane = Zarko Gajic
Kuupäev = 01/29/2009
[Paigutus]
Ülemine = 20
Vasakpoolne = 35
Laius = 500
Kõrgus = 340
Pange tähele, et võti nimega Viimane hoiab stringi väärtust, Kuupäev hoiab väärtust TDateTime ja kõiki klahve Paigutamine jaotis hoiab täisarvu.
Põhivormi OnCreate sündmus on ideaalne koht rakenduse lähtestamisfaili väärtustele juurdepääsu saamiseks vajaliku koodi talletamiseks:
protseduur TMainForm. FormCreate (saatja: TObject);
var
appINI: TIniFile;
Viimane kasutaja: string;
Viimane kuupäev: TDateTime;
alustada
appINI: = TIniFile. Loo (ChangeFileExt (rakendus. ExeName, '. Ini'));
proovida
// kui ükski viimane kasutaja ei tagasta tühja stringi
Viimane kasutaja: = appINI.ReadString ('Kasutaja', 'Viimane', '');
// kui viimast kuupäeva pole, naaseb tänane kuupäev
LastDate: = appINI.ReadDate ('Kasutaja', 'Kuupäev', Kuupäev);
// näita sõnumit
ShowMessage ('Seda programmi kasutasid varem' + LastUser + 'saidil' + DateToStr (LastDate));
Ülaosa: = appINI.ReadInteger ('Paigutus', 'Ülalt', Ülalt);
Vasakpoolne: = appINI.ReadInteger ('Paigutus', 'Vasak', Vasak);
Laius: = appINI.ReadInteger ('Paigutus', 'Laius', Laius);
Kõrgus: = appINI.ReadInteger ('Paigutus', 'Kõrgus', Kõrgus);
lõpuks
appINI.vaba;
lõpp;
lõpp;
Põhivormi sündmus OnClose sobib ideaalselt Salvesta INI projekti osa.
protseduur TMainForm. FormClose (saatja: TObject; var Toiming: TCloseAction);
var
appINI: TIniFile;
alustada
appINI: = TIniFile. Loo (ChangeFileExt (rakendus. ExeName, '. Ini'));
proovida
appINI.WriteString ('Kasutaja', 'Viimane', 'Zarko Gajic');
appINI.WriteDate ('Kasutaja', 'Kuupäev', Kuupäev);
koos appINI, MainForm teha
alustada
WriteInteger ('Paigutus', 'Ülalt', Ülalt);
WriteInteger ('Paigutus', 'Vasak', Vasak);
WriteInteger ('Paigutus', 'Laius', Laius);
WriteInteger ('Paigutus', 'Kõrgus', Kõrgus);
lõpp;
lõpuks
appIni. Tasuta;
lõpp;
lõpp;
INI sektsioonid
EraseSection kustutab INI-faili terve sektsiooni. ReadSection ja ReadSections täitke objekt TStringList INI-faili kõigi sektsioonide (ja võtmenimedega) nimedega.
INI piirangud ja varjuküljed
TIniFile klass kasutab Windowsi API mis seab INI-failidele 64 KB limiidi. Kui teil on vaja salvestada rohkem kui 64 KB andmeid, peaksite kasutama TMemIniFile.
Teine probleem võib tekkida, kui teil on sektsioon, mille väärtus on üle 8 K. Üks viis probleemi lahendamiseks on kirjutada oma versioon ReadSection meetodist.