Różnice między wybraną wersją a wersją aktualną.
Both sides previous revision Previous revision Next revision | Previous revision Next revision Both sides next revision | ||
xerces_dom [2008/04/14 21:12] kmioduszewski |
xerces_dom [2008/04/14 23:59] kmioduszewski |
||
---|---|---|---|
Linia 1: | Linia 1: | ||
====== biblioteka dla XML: Xerces (DOM) ===== | ====== biblioteka dla XML: Xerces (DOM) ===== | ||
- | Xerces-C++ DOM jest częścią Xerces-C++ API zaprojektowanego do współpracy z plikami w formacie XML. API umożliwia parsowania, manipulowanie, walidowanie oraz generowanie poprawnych dokumentów. | + | --- //[[kmioduszewski@polibuda.info|Krzysztof Mioduszewski]] 2008/04/14 23:59// |
+ | Xerces-C++ DOM jest częścią Xerces-C++ API zaprojektowanego do współpracy z plikami w formacie XML. API umożliwia parsowania, manipulowanie, walidowanie oraz generowanie poprawnych dokumentów. | ||
\\ | \\ | ||
Biblioteka DOM jest implementacją następujących rekomendacji W3C: | Biblioteka DOM jest implementacją następujących rekomendacji W3C: | ||
Linia 67: | Linia 68: | ||
} | } | ||
</code> | </code> | ||
+ | |||
Linia 78: | Linia 80: | ||
Jest to parser umożliwiający wczytanie do pamięci struktury pliku XML za pomocą metody ''parse()''. Po czym uzyskujemy dostęp do obiektu ''DOMDocument'', po którym możemy poruszać się wykorzystując zaimplementowane w zgodzie z rekomendacjami W3C metody. | Jest to parser umożliwiający wczytanie do pamięci struktury pliku XML za pomocą metody ''parse()''. Po czym uzyskujemy dostęp do obiektu ''DOMDocument'', po którym możemy poruszać się wykorzystując zaimplementowane w zgodzie z rekomendacjami W3C metody. | ||
- | Poniżej przykładowe fragmenty kodu dotyczącego inicjalizacji i korzystania z XercesDOMParser. | + | Poniżej przykładowe fragmenty kodu dotyczącego inicjalizacji i korzystania z ''XercesDOMParser''. |
<code cpp> | <code cpp> | ||
xercesc::XercesDOMParser* parser = new xercesc::XercesDOMParser(); | xercesc::XercesDOMParser* parser = new xercesc::XercesDOMParser(); | ||
Linia 99: | Linia 101: | ||
} | } | ||
+ | //sprawdzamy czy nie wystąpiły błędy podczas parsowania | ||
if(parser->getErrorCount()==0) { | if(parser->getErrorCount()==0) { | ||
xercesc::DOMDocument* XMLdoc = parser->getDocument(); | xercesc::DOMDocument* XMLdoc = parser->getDocument(); | ||
Linia 136: | Linia 139: | ||
</code> | </code> | ||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | |||
+ | ===== DOMDocument, operacje na dokumencie===== | ||
+ | Gdy dokument zostanie sparsowany bez żadnych błędów możemy swobodnie zacząć na nim pracować wykorzystując zawarte w rekomendacjach metody. Poniżej kod zawierający przykładowe operacje: | ||
+ | <code cpp> | ||
+ | //... | ||
+ | |||
+ | xercesc::DOMDocument* XMLdoc = parser->getDocument(); | ||
+ | xercesc::DOMElement* root = XMLdoc->getDocumentElement(); | ||
+ | |||
+ | //pobieramy nazwę elementu głównego | ||
+ | char* rootName = XMLString::transcode(root->getLocalName()); | ||
+ | |||
+ | if(root->hasAttributes()) { | ||
+ | xercesc::DOMNamedNodeMap* attrMap = root->getAttributes(); | ||
+ | //iterujemy sobie po atrybutach | ||
+ | for( XMLSize_t i = 0 ; i < attrMap->getLength() ; ++i ) { | ||
+ | DOMAttr* attr = dynamic_cast<DOMAttr*>(attrMap->item(ix)); | ||
+ | //wykorzystujemy sobie atrybut | ||
+ | attr->getName(); //tutaj mamy nazwe | ||
+ | attr->getValue(); //wartosc | ||
+ | //... | ||
+ | } | ||
+ | } | ||
+ | |||
+ | |||
+ | |||
+ | |||
+ | </code> |