INI soubory
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu
Reklama

INI souboryINI soubory

 

INI soubory

Google       Google       12. 5. 2006       19 609×

Dnešní díl je o ini souborech a registerch Windows.

Reklama
Reklama

Dnes jsou na řadě ini soubory a registry. Inicializační soubory (ini) slouží především k uchovávání nastavení nějakého programu, např. když si v našem programu napíšeme něco do editu, změníme velikost okna a uděláme další různé změny, můžeme je uložit do ini souboru a při příštím spuštění programu se nám otevře tak, jak byl nastaven při jeho zavření.

Dnes si naprogramujeme ukázkovou aplikaci, která nám uloží pozici okna, text, který bude napsán v editu, a jestli bude edit ReadOnly.

První věc, která je velmi důležitá, je ta, že přidáme do Uses jednotku IniFiles. Zde uvádím, co se bude provádět při vytvoření formuláře:


procedure TForm1.FormCreate(Sender: TObject);
var Ini: TIniFile;
begin
  Ini := TIniFile.Create('soubor.INI'); 
 
  Edit1.ReadOnly := Ini.ReadBool('Edit1', 'ReadOnly', 'false');
  Edit1.text := Ini.ReadString('Edit1', 'Text', '');
  Form1.Left := Ini.ReadInteger('Form1', 'Left', 300);
  Form1.Top := Ini.ReadInteger('Form1', 'Top', 300);
  
  Ini.Free; //uvolníme INI soubor s paměti
end;

Tímto jsme si načetli informace z ini souboru. První parametr, třeba u funkce ReadString, je sekce, ve které budeme hledat. Druhý je název údaje a třetí je defaultní hodnota, která se provede, když se nepodaří načíst data. Ukázka, jak bude náš ini soubor vypadat:


[Edit1]                   //Název sekce
ReadOnly=True             //Název údaje a jeho hodnota
Text=Toto je text :)      //Název údaje a jeho hodnota

[Form1]
Top=300
Left=300

A při ukončení programu informace uložíme:


procedure TForm1.FormClose(Sender: TObject; var Action: TCloseAction);
var Ini: TIniFile;
begin

    Ini := TIniFile.Create('soubor.INI');
    Ini.WriteBool('Edit1', 'ReadOnly', Edit1.ReadOnly);
    Ini.WriteString('Edit1', 'Text', Edit1.text);
    Ini.WriteInteger('Form1', 'Left', Form1.left);
    Ini.WriteInteger('Form1', 'Top', Form1.top);
    IniSoub.Free;

end;

První hodnota je zase název sekce, druhá je název hodnoty a třetí je to, co chceme uložit. Ukládat a číst musíme podle typů proměnných a dat. Jestliže chceme uložit (načíst) číslo, musíme použít funkci WriteInteger(ReadInteger).

WriteString
Zapíše řetězec
WriteInteger
Zapíše číslo
WriteBool
Zapíše true nebo false
ReadInteger
Přečte číslo
ReadString
Přečte řetězec
ReadBool
Přečte true nebo false

To je vše k ini souborům. Takto si můžeme snadno načíst (uložit) data, jenže někteří programátoři chtějí svá data schovat do registrů. V registrech je však plno dalších zajímavých věcí a plno dat ostatních programů. Registry si můžeme prohlížet a měnit pomocí programu Regedit, který je součástí Windows. Stačí zvolit Start-> Spustit-> Regedit. Popřípadě můžete tento prográmek nalézt v C:/Windows/system32/regedit.exe. Jako příklad si uděláme stejný program jako předtím, ale s tím rozdílem, že bude zapisovat data do registrů. Stejně jako u ini souborů, tak i u registrů musíme do Uses přidat jednotku Registry. Teď si napíšeme, co se bude dít při vytvoření formuláře:


procedure TForm1.FormCreate(Sender: TObject);
var Registry: TRegistry; //proměná registry je typu TRegistry
begin
 
//konstruktor, KEY_READ znamená, že můžeme data číst, ale nemůžeme je měnit
  Registry := TRegistry.Create(KEY_READ);  
  Registry.RootKey := HKEY_LOCAL_MACHINE; //nastavení kořenového klíče 

   if Registry.OpenKey('\Software\Nas_program\Nastaveni', False) then begin
      
      Edit1.Text := Registry.ReadString('Text');
      Edit1.ReadOnly := Registry.ReadBool('ReadOnly');
      Form1.Top := Registry.ReadInteger('Top');
      Form1.Left := Registry.ReadInteger('Left');

   end; 

    Registry.Free;
  end;
end; 

Na začátku jsme nastavili kořenový klíč HKEY_LOCAL_MACHINE. HKEY_LOCAL_MACHINE znamená, že data, která jsou tam uložená, může používat každý uživatel na daném PC. Je tam ještě HKEY_CURRENT_USER, což znamená, že tento kořenový klíč má každý uživatel jiný, vždy je v něm osobní nastavení daného uživatele. Tak jako u ini souborů, tak i u registrů používáme ReadString, ReadInteger atd. Parametrem OpenKey zjistíme, zda klíč existuje. Jelikož my jen čteme data, druhý parametr OpenKey necháme na false, protože to znamená, že by se měl klíč vytvořit. A teď potřebujeme ještě při ukončení aplikace data uložit do registru:


procedure TForm1.FormClose(Sender: TObject; var Action: TCloseAction);
var Registry: TRegistry;
begin
  // můžeme zapisovat, ale nemůžeme číst z registrů
  Registry := TRegistry.Create(KEY_WRITE);
  Registry.RootKey := HKEY_LOCAL_MACHINE; //nastavení kořenového klíče
    if Registry.OpenKey('\Software\Nas_program\Edit', True) then begin
      Registry.WriteString('Text', Edit1.Text);
      Registry.WriteBool('ReadOnly', Edit1.ReadOnly);
      Registry.WriteInteger('Top', Form1.Top);
      Registry.WriteInteger('Left', Form1.Left);
    end;
 
    Registry.Free;

end; 

Tip: Jestliže chcete, aby se vám váš program spustil při přihlášení uživatele, musíte napsat:


Registry := TRegistry.Create(KEY_WRITE);
Registry.RootKey := HKEY_LOCAL_MACHINE; 
if Registry.OpenKey('\SOFTWARE\Microsoft\Windows\CurrentVersion\Run', false) then

   Registry.WriteString('Nas program', application.exename);
 
Registry.Free;
RootKey nastavíme podle toho, zda chceme, aby se náš program spouštěl všem uživatelům, anebo jen uživateli, který program spustí. Druhý parametr, když ukládáme do klíče Run, musí být filename toho souboru, který chceme, aby se spouštěl.

To je vše. Příště už začnu psát takové krátké triky jako například průhledné okno, vypnutí cizí aplikace atd.

×Odeslání článku na tvůj Kindle

Zadej svůj Kindle e-mail a my ti pošleme článek na tvůj Kindle.
Musíš mít povolený příjem obsahu do svého Kindle z naší e-mailové adresy kindle@programujte.com.

E-mailová adresa (např. novak@kindle.com):

TIP: Pokud chceš dostávat naše články každé ráno do svého Kindle, koukni do sekce Články do Kindle.

4 názory  —  4 nové  
Hlasování bylo ukončeno    
0 hlasů
Google
Autor programoval v Visual Basicu, Delphi, nyní jen v Jave!

Nové články

Obrázek ke článku Malware KONNI se úspěšně skrýval 3 roky. Odhalil ho bezpečnostní tým Cisco Talos

Malware KONNI se úspěšně skrýval 3 roky. Odhalil ho bezpečnostní tým Cisco Talos

Bezpečnostní tým Cisco Talos odhalil celkem 4 kampaně dosud neobjeveného malwaru, který dostal jméno KONNI. Ten se dokázal úspěšně maskovat od roku 2014. Zpočátku se malware zaměřoval pouze na krádeže citlivých dat. Za 3 roky se ale několikrát vyvinul, přičemž jeho současná verze umožňuje útočníkovi z infikovaného počítače nejenom krást data, ale i mapovat stisky na klávesnici, pořizovat screenshoty obrazovky či v zařízení spustit libovolný kód. Pro odvedení pozornosti oběti zasílali útočníci v příloze také obrázek, zprávu a výhružkách severokorejského režimu či kontakty na členy mezinárodních organizací.

Reklama
Reklama
Obrázek ke článku Pouze jedna z deseti lokálních firem ví o pokutách plynoucích z GDPR

Pouze jedna z deseti lokálních firem ví o pokutách plynoucích z GDPR

Trend Micro, celosvětový lídr v oblasti bezpečnostních řešení a VMware, přední světový dodavatel cloudové infrastruktury a řešení pro podnikovou mobilitu, oznámily výsledky výzkumu mezi českými a slovenskými manažery zodpovědnými za ochranu osobních údajů, který zjišťoval, jak jsou připraveni na nové nařízení o ochraně osobních údajů (GDPR). Většina firem v České republice a na Slovensku nad 100 zaměstnanců je již s novým nařízením GDPR obeznámena. Výzkum provedený ve spolupráci s agenturou Ipsos ukázal, že téměř 8 firem z 10 o nařízení ví, přičemž jeho znalost je o něco vyšší na Slovensku (89 %) než v České republice (69 %).

Obrázek ke článku Vyděračský software Locky se vrací, tváří se jako potvrzení platby, odhalil tým Cisco Talos

Vyděračský software Locky se vrací, tváří se jako potvrzení platby, odhalil tým Cisco Talos

Jeden z nejznámějších ransomwarů, Locky, se vrací. Po většinu roku 2016 patřil mezi nejrozšířenější vyděračské softwary. Ke svému šíření využíval emailové kampaně s infikovanými přílohami. Ransomware Locky byl rozesílán prostřednictvím botnetu (internetový robot zasílající spamy) Necurs. Jeho aktivita na konci roku 2016 téměř upadla a spolu s ní i šíření ransomwaru Locky. Před několika týdny se Necurs opět probudil a začal posílat spamy nabízející výhodný nákup akcií. Dne 21. dubna zaznamenal bezpečnostní tým Cisco Talos první velkou kampaň ransomwaru Locky prostřednictvím botnetu Necurs za posledních několik měsíců.

Obrázek ke článku Dovozci baterií mění logistiku, letadlo nahrazuje námořní doprava

Dovozci baterií mění logistiku, letadlo nahrazuje námořní doprava

Dovozci baterií do mobilů či notebooků upouštějí od letecké přepravy zboží. V letošním roce plánují dovézt až 80 % produktů lodí. Přitom před 5 lety byla většina baterií do mobilních přístrojů dovezených do České republiky přepravována letadlem. Za proměnou způsobu transportu akumulátorů stojí zpřísnění pravidel pro leteckou přepravu, která přinášejí vyšší náklady i náročnou agendu.

loadingtransparent (function() { var po = document.createElement('script'); po.type = 'text/javascript'; po.async = true; po.src = 'https://apis.google.com/js/plusone.js'; var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(po, s); })();
Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032017 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý