sâmbătă, 22 septembrie 2012

Structura doc HTML

Limbajul HTML este compus din coduri speciale numite marcaje (sau tag-uri) care se insereaza intr-un document text pentru a specifica modul de formatare a acestuia. Orice marcaj este inclus intre doua paranteze unghiulare, ex: <nume_marcaj>, cu ajutorul careia browserul detecteaza si recunoaste acest simbol drept marcaj.

De obicei marcajele sunt in perechi (ex:<p>...</p>). Primul element este marcajul de deschidere iar cel de-al doilea este marcajul de inchidere, care are pus in fata numelui simbolul "/".

De mentionat ca exista si marcaje fara pereche, ca de exemplu marcajul <br>.
Ce inseamna si cum se utilizeaza marcajele<p>...</p>, <br> , vei afla in curand, dar pana atunci trebuie sa ai ideie despre structura unui document HTML!

  1.   Ce să mai citim?

  2. Ce să mai citim?

  3. Tatăl fondator al Uniunii Europene.            

  4. Colonizarea de pe Marte !

  5.   Ne pregătim pentru Marte

  6. Colonizarea Marte poate determina umanitatea să-și modifice ADN-ul ?

  7. Cine mai urăște să poarte mască?


Structura documentului HTML
Prezint in continuare structura unui document HTML alcatuit din partile lui principale care le voi explica mai jos:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
  <title>Pagina personala a lui Ion!</title>
</head>
<body>
................
</body>
</html>
Un document HTML se imparte in trei sectiuni:

  • Prima linie contine versiunea documentului HTML. Pana nu demult lispa acesteia nu influenta in nici un mod afisarea paginii. Totusi, includerea ei este recomandata cel putin din doua considerente:
      1. Asa o cere standardul 4.0
      2. Exista asa programe numite HTML validatoare, cu ajutorul careia se poate de verificat corectitudinea documentului. Pentru a analiza pagina web ele folosesc anume acea versiune care o ai indicata in pagina.
    <html> - Orice document html se incepe cu marcajul html
  • <head> - Cu acest marcaj se incepe cea de-a doua sectiune, care contine informatii ce nu se afiseaza in browser, cu exceptia marcajului <title> in care se specifica titlul paginii web si apare ca titlul ferestrei browser-ului.
    Marcajul <head> contine informatii cu privire la cuvintele cheie, descrierea saitului, inserare de cod JavaScript in pagina, etc.

  • <body> - In interiorul acestui marcaj se afla tot continutul paginii web care va aparea in browser (text, imagini,etc.).

Asta a fost o scurta introducere teoretica asupra structurii documentului HTML. Si de aici incolo, se incepe partea interesanta a cursului si anume studierea elementelor limbajului HTML! Sa incepem cu textul!




Cum să vezi sursa unei pagini 


Din când în când ne interesează să ne uităm în sursa unei pagini web – vrei, de exemplu, să vezi ce componentă, ce plugin ori ce temă folosește site-ul respectiv. În browserele moderne (Google Chrome, Firefox, Safari), acest lucru este posibil dând click dreapta pe pagina respectivă și alegând din meniul rapid opțiunea View Page Source.

Dar unele site-uri, în încercarea de a-și proteja conținutul, dezactivează click-ul dreapta – din punctul meu de vedere, acest lucru nu face decât să enerveze vizitatorii, căci cine vrea să copie ceva o poate face în voia cea bună accesând sursa paginii respective.

Să revin: pentru a accesa sursa paginii unui website care are dezactivat click dreapta, trebuie doar să adăugăm în fața adresei url două cuvinte – view-source:adresă_url.


Cum pot salva sursa unei pagini WEB?

Intentia mea este de a obtine niste date de pe o pagina web de la o adresa ex. www.un_site.ro. Pentru a obtine aceste date doresc sa salvez sursa acestei pagini intr-o variabila PHP, pentru ca mai apoi sa pot prelucra sirul de caractere din variabila in care s-a salvat sursa paginei respective. 
Nu prea am idee deloc cum ar trebui facut. Stie cineva ?


file

(PHP 4, PHP 5, PHP 7)
file — Reads entire file into an array

Descrierea ¶

array file ( string $filename [, int $flags = 0 [, resource $context ]] )
Reads an entire file into an array.
Notă:
You can use file_get_contents() to return the contents of a file as a string.

Parametri ¶

filename
Path to the file.
Sfat
Un URL poate fi utilizat în calitate de denumire a fișierului în această funcție dacă învelișurile fopen au fost activate. Accesați fopen() pentru mai multe detalii despre modul de specificare a denumirii fișierului. Accesați Supported Protocols and Wrappers pentru referințe la informații despre posibilitățile pe care le oferă diferite învelișuri, note despre utilizarea lor și informații despre variabile predefinite pe care le oferă.
flags
The optional parameter flags can be one, or more, of the following constants:
FILE_USE_INCLUDE_PATH
Search for the file in the include_path.
FILE_IGNORE_NEW_LINES
Do not add newline at the end of each array element
FILE_SKIP_EMPTY_LINES
Skip empty lines
context
A context resource created with the stream_context_create() function.
NotăSusținrea contextelor a fost adăugată începând cu PHP 5.0.0. Pentru o descriere a contextelor, referiți-vă la Streams.

Valorile întoarse ¶

Returns the file in an array. Each element of the array corresponds to a line in the file, with the newline still attached. Upon failure, file() returns FALSE.
Notă:
Each line in the resulting array will include the line ending, unless FILE_IGNORE_NEW_LINES is used, so you still need to use rtrim() if you do not want the line ending present.
NotăDacă PHP nu recunoaște corect terminațiile liniilor atunci când citește fișiere pe, sau create pe un computer Macintosh, atunci activarea opțiunii de configurare la rulareauto_detect_line_endings ar trebui să ajute la soluționarea problemei.

Erori/Excepții ¶

Emits an E_WARNING level error if the file does not exist.

Istoricul schimbărilor ¶

VersiuneDescriere
4.3.0file() became binary safe

Exemple ¶

Example #1 file() example
<?php// Get a file into an array.  In this example we'll go through HTTP to get
// the HTML source of a URL.
$lines file('http://www.example.com/');
// Loop through our array, show HTML source as HTML source; and line numbers too.foreach ($lines as $line_num => $line) {
    echo 
"Line #<b>{$line_num}</b> : " htmlspecialchars($line) . "<br />\n";
}
// Another example, let's get a web page into a string.  See also file_get_contents().$html implode(''file('http://www.example.com/'));
// Using the optional flags parameter since PHP 5$trimmed file('somefile.txt'FILE_IGNORE_NEW_LINES FILE_SKIP_EMPTY_LINES);?>

Note 

Avertizare
La utilizarea SSL, Microsoft IIS va viola protocolul prin închiderea conexiunii fără a trimite un indicator close_notify. PHP va raporta aceasta ca "SSL: Fatal Protocol Error" (eroare fatală de protocol) când se ajunge la sfârșitul datelor. Pentru a evita aceasta coborât nivelul error_reporting pentru a nu include avertizări. PHP poate detecta soft-ul de server IIS care produce astfel de greșeli când deschideți fluxul utilizând învelișul https:// și va suprima automat avertizările. La utilizarea fsockopen() pentru a crea un socket ssl:// programatorul este responsabil să detecteze și să suprime această avertizare.

A se vedea și 

add a note add a note

User Contributed Notes 12 notes

21
d basin 
8 years ago
this may be obvious, but it took me a while to figure out what I was doing wrong. So I wanted to share. I have a file on my "c:\" drive. How do I file() it?

Don't forget the backslash is special and you have to "escape" the backslash i.e. "\\":

<?php

$lines 
file("C:\\Documents and Settings\\myfile.txt");

foreach(
$lines as $line)
{
    echo(
$line);
}
?>

hope this helps...
22
bingo at dingo dot com 
4 years ago
To write all the lines of the file in other words to read the file line by line you can write the code like this:
<?php
$names
=file('name.txt');// To check the number of lines echo count($names).'<br>';
foreach(
$names as $name)
{
   echo 
$name.'<br>';
}
?>
this example is so basic to understand how it's working. I hope it will help many beginners.

Regards,
Bingo
8
Martin K. 
If the file you are reading is in CSV format do not use file(), use fgetcsv().  file() will split the file by each newline that it finds, even newlines that appear within a field (i.e. within quotations).
10
twichi at web dot de 
read from CSV data (file) into an array with named keys

... with or without 1st row = header (keys)
(see 4th parameter of function call as  true / false)

<?php // --------------------------------------------------------------
function csv_in_array($url,$delm=";",$encl="\"",$head=false) {
   
    
$csvxrow file($url);   // ---- csv rows to array ----
   
    
$csvxrow[0] = chop($csvxrow[0]);
    
$csvxrow[0] = str_replace($encl,'',$csvxrow[0]);
    
$keydata explode($delm,$csvxrow[0]);
    
$keynumb count($keydata);
   
    if (
$head === true) {
    
$anzdata count($csvxrow);
    
$z=0;
    for(
$x=1$x<$anzdata$x++) {
        
$csvxrow[$x] = chop($csvxrow[$x]);
        
$csvxrow[$x] = str_replace($encl,'',$csvxrow[$x]);
        
$csv_data[$x] = explode($delm,$csvxrow[$x]);
        
$i=0;
        foreach(
$keydata as $key) {
            
$out[$z][$key] = $csv_data[$x][$i];
            
$i++;
            }   
        
$z++;
        }
    }
    else {
        
$i=0;
        foreach(
$csvxrow as $item) {
            
$item chop($item);
            
$item str_replace($encl,'',$item);
            
$csv_data explode($delm,$item);
            for (
$y=0$y<$keynumb$y++) {
               
$out[$i][$y] = $csv_data[$y];
            }
        
$i++;
        }
    }

return 
$out;
}
// --------------------------------------------------------------
?>
fuction call with 4 parameters:

(1) = the file with CSV data (url / string)
(2) = colum delimiter (e.g: ; or | or , ...)
(3) = values enclosed by (e.g: ' or " or ^ or ...)
(4) = with or without 1st row = head (true/false)

<?php
// ----- call ------ $csvdata csv_in_array$yourcsvfile";""\""true ); // -----------------

// ----- view ------ 
echo "<pre>\r\n"print_r($csvdata);
echo 
"</pre>\r\n"// -----------------
?>
PS: also see: http://php.net/manual/de/function.fgetcsv.php to read CSV data into an array
... and other file-handling methods

^
0
lanresmith 
Using if ( file(name.txt) ) might not be enough for testing if the file was successfully opened for reading because the file could be empty in which case the array returned is empty, so test instead with !==. e.g.:

$file_array = file('test.txt'); // an empty file

echo '<pre>';
if ( $file_array ) {
    # code...
    echo "success\n";
} else {
    # code...
    echo "failure\n"; // executed
}

if ( $file_array !== false ) {
    # code...
    echo "success\n"; // executed
} else {
    # code...
    echo "failure\n";
}
echo '</pre>';

result:
failure
success
-2
Anonymous 
("file()'s problem with UTF-16" is wrong. This is updated.
The former may miss the last line of the string.)

file() seems to have a problem in handling
UTF-16 with or without BOM.

file() is likely to think "\n"=LF (0A) as a line-ending.
So, not only "000A" but also "010A, 020A,...,FE0A, FF0A,..."
are regarded as line-endings.

Moreover, file() causes a serious problem in UTF-16LE.
file() loses first "0A" (the first half of "0A00")!
And the next line begins with "00" (the rest of "0A00").
So lines after the first "0A" are totally different.

To avoid this phenomena,
eg. in case (php_script : UTF-8 , file : UTF-16 with line-ending "\r\n"),

<?php

mb_regex_encoding
('UTF-16');    // to help mb_ereg_..() work properly$str file_get_contents($file_path);$to_encoding 'UTF-16';        // encoding of string$from_encoding 'UTF-8';        // encoding of PHP_script$pattern1 mb_convert_encoding('[^\r]*\r\n'$to_encoding$from_encoding);mb_ereg_search_init($str$pattern1);
while (
$res mb_ereg_search_regs()) {
    
$file[] = $res[0];
}
$pattern2 mb_convert_encoding('\A.*\r\n(.*)\z'$to_encoding$from_encoding);mb_ereg($pattern2$str$match);
    
$file[] = $match[1];
?>
instead of
$file = file($file_path);

If line-ending is "\n",
$pattern1 = mb_convert_encoding('[^\n]*\n', $to_encoding, $from_encoding);
-9
jon+spamcheck at phpsitesolutions dot com 
A user suggested using rtrim always, due to the line ending conflict with files that have an EOL that differs from the server EOL.

Using rtrim with it's default character replacement is a bad solution though, as it removes all whitespace in addition to the '\r' and '\n' characters.

A good solution using rtrim follows:

<?php
$line 
rtrim($line"\r\n") . PHP_EOL;?>
This removes only EOL characters, and replaces with the server's EOL character, thus making preg_* work fine when matching the EOL ($)
-9
justin at visunet dot ie 
14 years ago
Note: Now that file() is binary safe it is 'much' slower than it used to be. If you are planning to read large files it may be worth your while using fgets() instead of file() For example:

<?php
$fd 
fopen ("log_file.txt""r");
while (!
feof ($fd))
{
   
$buffer fgets($fd4096);
   
$lines[] = $buffer;
fclose ($fd); ?> 
The resulting array is $lines.

I did a test on a 200,000 line file. It took seconds with fgets()  compared to minutes with file().
-8
vbchris at gmail dot com 
If you're getting "failed to open stream: Permission denied" when trying to use either file() or fopen() to access files on another server. Check your host doesn't have any firewall restrictions in-place which prevent outbound connections. This is the case with my host Aplus.net
-11
Reversed: moc dot liamg at senroc dot werdna 
This note applies to PHP 5.1.6 under Windows (although may apply to other versions).

It appears that the 'FILE_IGNORE_NEW_LINES' flag doesn't remove newlines properly when reading Windows-style text files, i.e. files whose lines end in '\r\n'.

Solution: Always use 'rtrim()' in preference to 'FILE_IGNORE_NEW_LINES'.
-13
marco dot remy at aol dot com ¶
Here's my CSV converter
supports Header and trims all fields
Note: Headers must be not empty!

<?php
function csv2array($file$delim ';'$encl '"'$header false) {
   
    
# File does not exist
    
if(!file_exists($file))
        return 
false;
   
    
# Read lines of file to array
    
$file_lines file($fileFILE_IGNORE_NEW_LINES FILE_SKIP_EMPTY_LINES);
   
    
# Empty file
    
if($file_lines === array())
        return 
NULL;
   
    
# Read headers if you want to
    
if($header === true) {
        
$line_header array_shift($file_lines);
        
$array_header array_map('trim'str_getcsv($line_header$delim$encl));
    }

    
$out NULL;

    
# Now line per line (strings)
    
foreach ($file_lines as $line) {
        
# Skip empty lines
        
if(trim($line) === '')
            continue;
       
        
# Convert line to array
        
$array_fields array_map('trim'str_getcsv($line$delim$encl));
       
        
# If header present, combine header and fields as key => value
        
if($header === true)
            
$out[] = array_combine ($array_header$array_fields);
        else
            
$out[] = $array_fields;
    }
   
    return 
$out;
}
?>
-25
info at carstanje dot com 
Using file() for reading large text files > 10 Mb gives problems, therefore you should use this instead. It is much slower but it works fine. $lines will return an array with all the lines.

<?php
$handle 
= @fopen('yourfile...'"r");
if (
$handle) {
   while (!
feof($handle)) {
       
$lines[] = fgets($handle4096);
   }
   
fclose($handle);
?>





Introducere in HTML

Limbajul HTML este usor de invatat dar pentru aceasta 
este necesar sa exersezi cat mai mult

Aparitia 
HTML

HTML apare in anul 1989 la CERN(Centrul European de Cercetari Nucleare de la Geneva) iar dezvoltatorul initial este Tim Berners-Lee. Scopul acestuia a fost facilitarea accesului rapid la informatiile tehnice cuprinse in manualele de utilizare a calculatoarelor.

Ce este HTML?
HTML este prescutarea de la HyperTextMarkupLanguage, este un limbaj de marcare universal interpretat de browsere si se foloseste pentru elaborarea deferitor documente text cu linkuri si elemente multimedia - pagini web, prezentari, carti electronice.
Fisierele HTML sunt fisiere text. Datorita acesteia ele pot fi afisate si modificate pe orice calculator cu orice sistem de operare. Extensia unui fisier html este .htm sau .html.


HTML este limbaj de programare?
HTML nu este limbaj de programare. Sarcina lui este afisarea documentului html si pune la dispozitie diferite mijloace de formatare a textului. Deaceea, pentru ca paginile HTML sa execute ceva ca raspuns la actiunile utilizatorului, de exemplu sa afiseze un mesaj sau sa interschimbe niste imagini, se recurg la mijloace specializate care largesc posibilitatilie HTML-ului, cum ar fi limbajul de programare JavaScript.

Instrumente necesare
Pentru crearea paginilor HTML se poate utiliza orice editor text sau editor grafic.
Din categoria editoarelor text, cel mai simplu si la indemana este editorul notepad. Dupa scriera codului in notepad salvati fisierul cu extensia .html si in rezultat veti obtine o pagina web. Exista editoare text specializate care ofera mai multe avantaje, cum ar fi evidentierea tag-urilor limbajului, ceea ce e necesar pentru o mai buna lizibilitate a codului (de exemplu HTML Kit care este distribuit gratis).
Din categoria editoarele grafice fac parte Macromedia Dreamweaver, WebPageMaker. 
Sunt medii care nu cer cunostinte avansate de HTML. Mai mult, unele iti permit sa creezi pagini web fara sa ai ideie de limbajul HTML. 
Cu ajutorul acestor programe vei reusi sa creezi o pagina web intr-un timp rapid, insa editarea acesteia va deveni costisitoare din cauza ca aceste programe genereaza un cod lung, neoptimal si de multe ori greu de inteles.

Cat de greu se invata HTML?
Limbajul HTML este usor de invatat dar pentru aceasta este necesar sa exersezi cat mai mult, si cel mai important este sa scrii tu codul pentru fiecare exemplu in parte. Chiar daca unele exemple ti se par prea simple si te gandesti ca taparea lor ti-ar stoarce din timp, sfatul meu este sa le scrii pentru ca asa vei memora mai bine. Scriind chiar si lucruri simple de multe ori vei face greseli si in asa mod vei dobandi mai multa practica!

Cum poţi deveni programator în mai puţin de 6 luni şi să ajungi să câştigi aproape 1.000 de euro/lună

Poţi să înveţi bazele programării singur, în mai puţin de o lună, indiferent de studiile pe care le ai, cu condiţia să fii pasionat, motivat şi ambiţios şi să investeşti suficient timp, însă pentru a deveni un programator de top sunt necesare cel puţin 6 luni de efort susţinut, sunt de părere unii specialişti din domeniu.
Salariul pentru un programator entry-level într-o companie de top porneşte de la 800-1.000 de euro, iar după 3-5 ani poate ajunge la un nivel de 2.000 de euro, spune Răzvan Rughiniş, profesor la Facultatea de Automatică şi Calculatoare.
Deşi nu poţi să înveţi programare de la A la Z singur, bazele limbajelor sunt accesibile oricui vrea să înveţe, susţine Rughiniş. El recomandă celor care vor să înveţe programare singuri să înceapă cu limbaje mai uşoare, precum Python, a cărui popularitate se datorează simplităţii şi conciziei codului. Alte limbaje recomandate începătorilor sunt Java sau C#, spune Brânduşa Fecioru, director de HR la TotalSoft.
Şi Cătălin Alexandru, lead programmer la Ubisoft, este de părere că este uşor să înveţi singur programare şi algoritmică, întrucât, spune el, toate informaţiile necesare pot fi găsite în cărţi şi tutoriale online. Condiţia, consideră programatorul, este să stabileşti încă de la început un rezultat final către care să-ţi îndrepţi efortul de învăţare. “Bazele unui anumit limbaj de programare se pot învăţa repede, în câteva săptămâni, dar este nevoie de multă practică pentru a ajunge la un nivel înalt de performanţă. Mai mult, există multe subiecte conexe care trebuie învăţate în funcţie de contextul în care este utilizat respectivul limbaj de programare, precum fizică, matematică sau economie”, spune Alexandru. Tot el spune că, deşi  cunoaşterea unuia sau a mai multor limbaje de programare este importantă, esenţială este învăţarea procesului logic de exprimare a algoritmilor în cod, abilitate necesară indiferent de limbajul de programare utilizat.
Deşi există un număr mare de limbaje de programare (C, C++, C#, Java, Python, Ruby, Haskell, Scheme, prolog, Javascript, HTML/CSS), cele mai căutate limbaje sunt, potrivit Brânduşei Fecioru, Java, C, C#  şi JavaScript.
În ceea ce priveşte programarea pentru jocurile video, “cel mai important limbaj este C++, deoarece oferă un amestec ideal între performanţă, uşurinţă de utilizare şi putere de expresivitate”, spune Cătălin Alexandru. De asemenea, spune el, pentru cazuri particulare există alte limbaje de programare care sunt mai potrivite: C# când este nevoie de interfeţe complicate cu utilizatorul, Java când este nevoie de o portabilitate mare sau Python pentru unele categorii de plugin-uri (programe care se integrează altor programe de bază pentru a îndeplini funcţii specifice).
Pentru cei care vor să devină programatori, fără a avea însă facultate de profil, există cursuri şi seminarii, unele dintre ele gratuite. Organizaţia ROSEdu (rosedu.org) precum şi DevAcademy (devacademy.ro) au astfel de cursuri. “Deşi sunt numeroase platforme de unde poţi învăţa limbajele de programare, în general cele mai sigure sunt chiar tutorialele disponibile pe site-urile tehnologiilor respective”, spune Rughiniş.
Cătălin Alexandru recomandă cursurile online disponibile pe site-urile coursera.com, edx.org şi udacity.com, realizate în colaborare cu profesori de la facultăţi cunoscute. Cursurile, spune el, permit învăţarea în ritmul fiecăruia, iar unele dintre ele se bazează pe participarea activă a cursanţilor.
Povestea de viaţă a unor tineri care au învăţat programare singuri
Liviu, 28 de ani, absolvent al Facultăţii de Instalaţii pentru Construcţii din cadrul Universităţii Tehnice de Construcţii Bucureşti, a învăţat programare singur, condiţionat de situaţia financiară proastă pe care i-o oferea jobul în construcţii. El a învăţat cu ajutorul tutorialelor de pe internet şi al prietenilor, iar din 2012 lucrează la o firmă din domeniu şi câştigă 3.600 de lei (aproape 800 de euro), cu 2.000 de lei (440 de euro) mai mult decât la jobul anterior.
Liviu spune că a început cu câteva tutoriale de pe site-ul lynda.com şi symphony.com şi a citit mai multe cărţi de programare, deşi lucra în continuare la fostul job cu normă întreagă.
După 3-4 luni, Liviu a renunţat definitiv la construcţii şi s-a angajat la firma unor prieteni, aceiaşi care l-au sfătuit să-şi schimbe domeniul de activitate. Deşi a avut un traseu rapid, el spune că mai are încă multe de învăţat.
Un alt exemplu de autodidact, Marius, 25 de ani, care lucrează într-o firmă de programare încă de când era student, spune că ce ştie a învăţat tot pe cont propriu, deşi a urmat o facultate de profil. Marius a început să se familiarizeze cu bazele programării încă din liceu, iar apoi a continuat la Facultatea de Automatică şi Calculatoare, unde a studiat limbaje pe care nu le-a mai folosit niciodată după absolvire. Aşadar, el a trebuit să studieze singur, folosind site-uri precum w3schools.com sau stackoverflow.com.
Marius crede că cele mai uşoare limbaje de programare, recomandate pentru începători, sunt HTML şi JavaScript, iar cel mai greu, dar şi cel mai utilizat, este Java, urmat în topul cerinţelor pe piaţa din România de rivalul de la Microsoft, tehnologia .Net.
Trebuie menţionat, totuşi, că învăţarea programării este un proces continuu, care trebuie să se desfăşoare de-a lungul întregii cariere, spune Cătălin Alexandru.
Unde găseşti tutoriale
 Alte site-uri de unde poţi învăţa programare
 https://www.devmind.ro - preţul unui curs porneşte de la 550 de lei 
 http://www.lec-academy.ro/ - cursurile costă între 140 şi 890 de ron în funcţie de gradul de dificultate al limbajului de programare şi de nivelul dorit, încăpători sau avansaţi, de numărul de ore necesare pentru finalizarea cursului şi dacă se desfăşoară online sau în clasă
http://www.link-academy.com/Academy-_770_2_77_213 - un curs costă 1900 de lei şi pot fi plătit în rate; cursurile se pot desfăşura online sau în modul tradiţional de şcolarizare
https://www.invata-online.ro/   - preţul unul curs este de 160 de ron
 http://www.cursuri-programare.ro/ - preţul unui curs este de 450 de lei