Главная страница
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.47 MB
Время: 0.046 c
2-1228931359
zoldatten
2008-12-10 20:49
2009.01.25
a^15 за 5 операций умножения


2-1228895475
9899100
2008-12-10 10:51
2009.01.25
PolyLine


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


2-1228899008
Нов_и_чок
2008-12-10 11:50
2009.01.25
Некорректное отображение формы на экране!!!


3-1213733259
Ulti
2008-06-18 00:07
2009.01.25
БД paradox