Posted: August 20th, 2009 | Author: M.B. | Filed under: Articole, PHP | No Comments »
Acum ceva vreme am postat o modalitate rapidă de a preluat cursul valutar complet de la bnr. Azi un prieten căuta o modalitate la fel de rapidă de a prelua cursul valutar, însă doar pentru USD şi EURO, fără să preia toate valutele şi să verifice dacă sunt cele dorite. Cum se poate rezolva lucrul ăsta? Răspunsul este XPath.
/*
* initiez clasa DOMDocument, reprezentand fisierul xml incarcat
*/
$dom = new DOMDocument();
$dom->preserveWhiteSpace = false;
/*
* incarc fisierul xml, specificand adresa completa
*/
$dom->load( "http://www.bnro.ro/nbrfxrates.xml" , 'http://www.bnr.ro/xsd');
/*
* preiau intr-un obiect iterabil (DOMNodeList) lista elementelor ce indeplinesc doleantele mele
*/
$valute = $xpath->query( "xsd:Body/xsd:Cube/xsd:Rate[@currency='USD' or @currency='EUR']" );
/*
* verific daca sunt elemente de acest tip
*/
if ( $valute )
{
$new_valute = array();
/*
* in caz afirmativ, iterez prin ele si le preiau intr-un array ce-mi convine
*/
foreach ( $valute as $valuta )
{
$new_valute[$valuta->getAttribute('currency')] = $valuta->nodeValue;
}
}
Prin XPath putem selecta rapid doar elementele care corespund anumitor criterii, căutând după o cale (path) indicată de noi. În cazul în care fişierul xml conţine namespace-uri (ca în cazul acesta) ele trebuie anunţate la început, pentru că altfel nu vom primi nici un rezultat. Good luck
Tags: bnr,
curs valutar,
dom,
PHP,
xpath
Posted: September 25th, 2008 | Author: M.B. | Filed under: Articole, PHP | 2 Comments »
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:
National Bank of Romania
2008-09-25
DR
Reference rates
RON
2.0985
1.8802
2.4202
2.3059
0.1505
0.4930
0.4583
3.6773
4.6475
1.5275
2.3608
0.2414
0.4452
1.1040
0.1000
0.3800
0.1214
2.0194
2.5001
71.4560
3.9396
(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 . "
";
}
}
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ă
Tags: bnr,
curs valutar,
dom,
PHP,
preluare