Posted by: misterjinx on: septembrie 25, 2008
Azi am fost nevoit să preiau cursul valutar de pe site-ul bnr pentru a-l stoca în baza de date. Ştiu că erau pe nu ştiu ce site-uri puse la dispoziţie coduri care fac treaba asta, însă după mine într-o manieră foarte alandala. După mine cel mai simplu de parsat un fişier xml (cum este cel pus la dispoziţie de bnr) este folosind extensiile puse la dispoziţie de php, SimpleXML şi DOM. Eu am ales să folosesc DOM, deoarece rezolvă foarte repede ceea ce am avut nevoie.
Structura fişierului xml care trebuie parsat este urătoarea:
<DataSet xsi:schemaLocation=”http://www.bnr.ro/xsd nbrfxrates.xsd”>
<Header>
<Sender>National Bank of Romania</Sender>
<SendingDate>2008-09-25</SendingDate>
<MessageType>DR</MessageType>
</Header>
<Body>
<Subject>Reference rates</Subject>
<OrigCurrency>RON</OrigCurrency>
<Cube date=”2008-09-25″>
<Rate currency=”AUD”>2.0985</Rate>
<Rate currency=”BGN”>1.8802</Rate>
<Rate currency=”CAD”>2.4202</Rate>
<Rate currency=”CHF”>2.3059</Rate>
<Rate currency=”CZK”>0.1505</Rate>
<Rate currency=”DKK”>0.4930</Rate>
<Rate currency=”EGP”>0.4583</Rate>
<Rate currency=”EUR”>3.6773</Rate>
<Rate currency=”GBP”>4.6475</Rate>
<Rate currency=”HUF” multiplier=”100″>1.5275</Rate>
<Rate currency=”JPY” multiplier=”100″>2.3608</Rate>
<Rate currency=”MDL”>0.2414</Rate>
<Rate currency=”NOK”>0.4452</Rate>
<Rate currency=”PLN”>1.1040</Rate>
<Rate currency=”RUB”>0.1000</Rate>
<Rate currency=”SEK”>0.3800</Rate>
<Rate currency=”SKK”>0.1214</Rate>
<Rate currency=”TRY”>2.0194</Rate>
<Rate currency=”USD”>2.5001</Rate>
<Rate currency=”XAU”>71.4560</Rate>
<Rate currency=”XDR”>3.9396</Rate>
</Cube>
</Body>
</DataSet>
(evident documentul nu este valid, dar nu ne interesează asta
)
După cum se observă, ce trebuie noi să facem este preluarea tuturor tagurilor cu numele „Rate”. Apoi preluăm numele valutei folosind metoda getAttribute, care returnează valoarea atributului cu numele specificat.
Iată codul care pune în aplicare cele spuse mai sus:
/*
* initiez clasa DOMDocument, reprezentand fisierul xml incarcat
*/
$dom = new DOMDocument();
/*
* incarc fisierul xml, specificand adresa completa
*/
$dom->load( “http://www.bnro.ro/nbrfxrates.xml” );/*
* preiau intr-un obiect iterabil lista elementelor(tagurile) cu numele specificat
*/
$valute = $dom->getElementsByTagName(‘Rate’);/*
* verific daca sunt elemente de acest tip
*/
if ( $valute->length != 0 )
{
/** in caz afirmativ, iterez prin ele si le afiez
* ( evident le pot stoca intr-un array sau chiar in baza de date,
* dupa caz)
*/
foreach ( $valute as $valuta )
{
echo $valuta->getAttribute(currency). ” – ” .$valuta->nodeValue . “<br/>”;
}
}
Dacă nu punem la socoteală, liniile comentate, putem prelua codul bnr în doar 8 linii de cod ! În acelaşi mod se pot prelua şi diferite feed-uri de pe diverse site-uri. Baftă
septembrie 26, 2008 la 8:28 am
nice
hai ca se poate… la cat mai multe
// cum iti dai seama daca bnr-ul schimba structura xml-ului sau denumirile tagurilor / atributelor ?
(mai trebuie cateva verificari si un sistem de alertare real time)