Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2009.01.25;
Скачать: CL | DM;

Вниз

Как обойти дерево всех IXMLNode элементов?   Найти похожие ветки 

 
Алексей121   (2008-12-12 12:49) [0]

Есть дерево в виде XML документа. Мне нужно у какого-нибудь нода просмотреть все его элементы на всех уровнях вложенности.
Есть ли стандартные методы?
Делаю так (метод из итератора):

CurrentNode: IXMLNode;
...
procedure TaxXMLNodeIterator.Next;
begin
 if CurrentNode = nil then
    raise ExceptClass.Create("Вызову Next должна предшедствовать проверка на not IsDone");

 if CurrentNode.ChildNodes.Count > 0 then
   CurrentNode := CurrentNode.ChildNodes[0]
 else
 if CurrentNode.NextSibling <> nil then
   CurrentNode := CurrentNode.NextSibling
 else
 if CurrentNode.ParentNode.NextSibling <> nil then
   CurrentNode := CurrentNode.ParentNode.NextSibling
 else
   CurrentNode := nil;

end;


Этот алгоритм неправильный.


 
clickmaker ©   (2008-12-12 13:01) [1]

> все его элементы на всех уровнях вложенности

рекурсивно?


 
int64   (2008-12-12 13:08) [2]

Да как угодно. Нужно, чтобы метод Next переводил CurrentNode на следующий нод


 
clickmaker ©   (2008-12-12 13:14) [3]

а он не переводит?


 
int64   (2008-12-12 13:28) [4]


> а он не переводит?

Только, если дополнить следующим чудом:

> else
>  if CurrentNode.ParentNode.NextSibling <> nil then
>    CurrentNode := CurrentNode.ParentNode.NextSibling
> else
>  if CurrentNode.ParentNode.ParentNode.NextSibling <> nil
> then
>    CurrentNode := CurrentNode.ParentNode.ParentNode.NextSibling
> else
>  if CurrentNode.ParentNode.ParentNode.ParentNode.NextSibling
> <> nil then
>    CurrentNode := CurrentNode.ParentNode.ParentNode.ParentNode.
> NextSibling
> ...


 
int64   (2008-12-12 13:47) [5]

ANode := CurrentNode;

while (ANode.ParentNode <> nil) and (ANode.ParentNode.NextSibling = nil)
ANode := ANode.ParentNode;
if ANode.ParentNode = nil then
  CurrentNode:= nil
else
  CurrentNode := ANode.ParentNode.NextSibling



Страницы: 1 вся ветка

Текущий архив: 2009.01.25;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.014 c
2-1228999751
9899100
2008-12-11 15:49
2009.01.25
градиент


15-1227691000
Jeer
2008-11-26 12:16
2009.01.25
Проверка на сисадминность


2-1228929035
lewka
2008-12-10 20:10
2009.01.25
Коды кнопок


15-1228137159
pavel_guzhanov
2008-12-01 16:12
2009.01.25
как зарегистрировать TurboDelphi 2006?


1-1207151915
Кодер
2008-04-02 19:58
2009.01.25
Курсор и блокировка формы