Ошибка: Failed to parse the Currency Converter XML document.
$879.10
|
Ошибка: Failed to parse the Currency Converter XML document.
$48 104.52
|
Ошибка: Failed to parse the Currency Converter XML document.
$6 001.13
|
Delphi. Работа с реестром
Работа с реестром разделяется на несколько этапов.
1. Вы должны объявить подключение модуля registry в uses.
2. Необходимо создать переменную типа tregistry и инициализировать ее. 3. Собственно работа с реестром.
4. Уничтожение переменной.
uses
..., registry,...
var
reg:tregistry; // Создание переменной reg
begin
reg:=tregistry.create; // Инициализирование этой же переменной
//------------ Программа------------
reg.destroy;
end;
Пункты 1, 2, 4 - ясны. Поэтому оставшаяся часть статьй будет посвящена именно 3-му пункту работе с реестром. Самое первое дело, после выполнения второго пункта, это определение корневого ключа реестра. Он определяется с помощью свойства rootkey переменной reg.
Корневые ключи реестра:
hkey_classes_root (по умолчанию)
hkey_current_user
hkey_local_machine
hkey_users
hkey_current_config
hkey_dyn_data
Следующие свойства:
currentpath: string; Определяет путь к текущему ключу. currentkey: hkey; Определяет открытый в настоящее время ключ реестра.
procedure closekey;
Закрывает открытый в данный момент ключ реестра и записывает в реестра все изменения (если таковые были), произведенные в данном ключе. Вызов closekey несколько раз или при отсутствии открытого ключа не вызывает ошибки.
function createkey(const key: string): boolean;
Создает ключ key (где key путь с разделителями «», например softwaretest. Имя корневого ключа в пути не указывается !! Он задается через property rootkey. Возвращает true при успешном создании
function deletekey(const key: string): boolean;
Удалить ключ key (аналогично createkey, только с точностью до наоборот)
function delete value(const name: string): boolean;
Удалить параметр с именем name текущего ключа. Очевидно, что предварительно необходимо открыть этот ключ
function getdatainfo(const valuename: string; var value: tregdatainfo): boolean;
Получить информацию о параметре valuename текущего ключа его тип и размер. При написании программ применяется редко, т.к. программист и сам знает, какого типа его параметры. А вот при написании разного рода утилит для просмотра и редактирования реестра он просто незаменим.
Типы:
tregdatatype = (rdunknown, rdstring, rdexpandstring, rdinteger, rdbinary);
tregdatainfo = record
regdata: tregdatatype; // Тип ключа
datasize: integer; // Размер данных end;
Данная функция возвращает комплексную информацию о параметре, для получения данных о размере или типе можно применять getdatasize и getdatatype
function getdatasize(const valuename: string): integer;
Получить размер параметра valuename текущего ключа в байтах. Если при ошибке. Для строкового параметра размер учитывает в размере и один байт для #0, завершающего строку .
function getdatatype(const valuename: string): tregdatatype;
Получить тип текущего ключа.
procedure getkeynames(strings: tstrings);
Заполняет указанный strings списком под ключей текущего ключа. Применяется для построения программ просмотра реестра или в том случае, когда количество подключей неизвестно. Например, одна из моих программ создает в одном из ключей несколько подключей с одинаковой структурой, но их количество заранее неизвестно (настройки пользователей).
procedure get valuenames(strings: tstrings);
Заполняет указанный strings списком параметров текущего ключа.
function hassubkeys: boolean;
Возвращает true, если текущий ключ имеет подключи и false в противном случае
function keyexists(const key: string): boolean;
Возвращает true, если ключ key существует. Полезная функция, рекомендуется применять ее перед открытием ключей.
function loadkey(const key, filename: string): boolean;
Создает ключ key и загружает в него данные из файла с именем filename. Полезно при написании инсталляторов. Возвращает true при успешном выполнении.
procedure movekey(const oldname, newname: string;
delete: boolean); Копировать или переименовать ключ. В любом случае копирует все из ключа oldname в newname (со всеми подключами). После копирования анализируется delete, и если он true, то ключ oldname уничтожается со всем содержимым. Лично у меня не было потребности в применении данной функции она не требуется программ и предначначена для построения редакторов реестра
function openkey(const key: string; cancreate: boolean): boolean;
Очень важная функция с нее начинается работа с ключом. key имя открываемого ключа. Если ключ с указанным именем не найден и cancreate=true, то производится попытка создать ключ с указанным именем. Возвращает признак успешности открытия ключа, его обязательно следует анализировать.
function openkeyreadonly(const key: string): boolean;
Тоже, что и openkey, но открытие идет в режиме «только чтение» Внимание !!!!!! Все функции типа read** при вызове генерируют исключение, если параметр не найден. Это исключение следует отлавливать при помощи try except или проверять наличие параметра при помощи valueexists перед его чтением.
function readbinarydata(const name: string; var buffer; bufsize: integer): integer;
Читает значение параметра с именем name текущего (открытого) ключа в buffer размером bufsize.
function readbool(const name: string): boolean;
Считать значение параметра с именем name типа boolean function
readdate(const name: string): tdatetime;
Считать значение параметра с именем name типа дата
function readdatetime(const name: string): tdatetime;
Считать значение параметра с именем name типа дата-время
function readtime(const name: string): tdatetime;
Считать значение параметра с именем name типа время
function readfloat(const name: string): double;
Считать значение параметра с именем name типа double
function readinteger(const name: string): integer;
Считать значение параметра с именем name типа integer
function readstring(const name: string): string;
Считать значение параметра с именем name типа string
function registryconnect(const uncname: string): boolean; Подключить сетевой реестр машины uncname (формат: сетевое имя машины). Перед вызовом этой функции программа должна установить rootkey в значение hkey_users или hkey_local_machine. При успешном соединении и открытии удаленного реестра его rootkey ставится в заданное перед вызовам значение свойства rootkey и возвращается true.
procedure rename value(const oldname, newname: string);
Переименовать параметр текущего ключа с именем oldname в newname.
function replacekey(const key, filename, backupfilename: string): boolean;
Заменить место хранения ключа. Обычно ключи хранятся в базовом файле реестра, нот вызовом данной функции можно задать в качестве места хранения ключа отдельный файл с именем filename (его следует предварительно создать при помощи savekey). При каждой перезагрузке компьютера ключ key будет загружаться значениями, считываемыми из файла этого файла filename,т.е. по сути мы имеет дело с ульем (hive) в терминологии windows nt. Определение: Улей часть реестра (его ячейка). Улей является дискретным набором ключей, подключей и параметров, который находится вверху иерархии реестра. Улей поддерживается одиночным файлом. backupfilename имя резервной копии, которая создается перед перезаписью данных ключа key. Если кого интересуют подробности, то следует почитать книгу по реестру windows nt, главы типа «Ульи и файлы» и «Целостность и восстановление улья в реестре». При разработке практических приложений я не разу не применял этот вызов.
function restorekey(const key, filename: string): boolean;
Открывает указанный ключ и перезаписывает его данные и подключи данными из файла filename.
function savekey(const key, filename: string): boolean;
Сохраняет все параметры указанного ключа и всех его подключей в файле filename. Может применяться совместно с loadkey и restorekey для создания и восстановления ключей реестра.
function unloadkey(const key: string): boolean;
Удалить улей key из реестра.
function valueexists(const name: string): boolean;
Проверить, существует ли в текущем ключе параметр с именем name. Весьма полезная функция, т.к. чтение несуществующего параметра приводит к исключительной ситуации
procedure writebinarydata(const name: string; var buffer; bufsize: integer);
Записать в параметр с именем name данные из буфера buffer размером bufsize. Если параметр существовал, то он будет перезаписан. Если параметр не существовал, то он будет создан. Это справедливо и для всех последующих процедур записи параметров
Остальные процедуры записи writebool, writecurrency,writedate,writedatetime, writeexpandstring, writefloat, writeinteger, writestring, writetime имеют по два параметра (имя ключа, значение ключа).
Ну вот, класс описали, теперь приведем парочку примеров.
Пример запись.
var reg : tregistry;
begin
reg := tregistry.create;
reg.rootkey:=hkey_local_machine; reg.openkey(«softwaretest»,true);
reg.writebool(«test1»,true);
reg.writeinteger(«test2»,12);
reg.closekey;
reg.destroy;
end;
Данный пример создает (если его не было) или открывает ключ реестра hkey_local_machinesoftwaretest и записывает в него два параметра типа boolean и integer