function from_unimarc($record)
 {
     $this->document_type = $record->inner_guide[dt];
     $this->bibliographic_level = $record->inner_guide[bl];
     $this->hierarchic_level = $record->inner_guide[hl];
     if ($this->hierarchic_level == "") {
         if ($this->bibliographic_level == "s") {
             $this->hierarchic_level = "1";
         }
         if ($this->bibliographic_level == "m") {
             $this->hierarchic_level = "0";
         }
     }
     if (function_exists("param_perso_prepare")) {
         param_perso_prepare($record);
     }
     $indicateur = array();
     for ($i = 0; $i < count($record->inner_directory); $i++) {
         $cle = $record->inner_directory[$i]['label'];
         $indicateur[$cle][] = substr($record->inner_data[$i]['content'], 0, 2);
         switch ($cle) {
             case "010":
                 /* isbn */
                 $isbn = $record->get_subfield($cle, 'a');
                 $subfield = $record->get_subfield($cle, "d");
                 $this->prix = $subfield[0];
             case "011":
                 /* isbn */
                 $isbn = $record->get_subfield($cle, 'a');
                 break;
             case "014":
                 /* isbn */
                 $this->others_ids = $record->get_subfield($cle, 'a', 'b');
                 break;
             case "071":
                 /* barcode */
                 $cb = $record->get_subfield($cle, "a");
                 break;
             case "101":
                 /* language */
                 //martizva NOTE: some server send language in UPCASE!!!
                 // $subfield = $record->get_subfield($cle,"a");
                 // $this->language_code = strtolower($subfield[0]);
                 // $subfield = $record->get_subfield($cle,"c");
                 // $this->original_language_code = strtolower($subfield[0]);
                 $this->language_code = $record->get_subfield_array($cle, "a");
                 $this->original_language_code = $record->get_subfield_array($cle, "c");
                 break;
             case "200":
                 /* titles */
                 $tit = $record->get_subfield($cle, 'a', 'c', 'd', 'e', 'v');
                 $tit_200a = $record->get_subfield_array($cle, 'a');
                 $tit_200c = $record->get_subfield_array($cle, 'c');
                 $tit_200d = $record->get_subfield_array($cle, 'd');
                 $tit_200e = $record->get_subfield_array($cle, 'e');
                 $tit_200v = $record->get_subfield_array($cle, 'v');
                 $this->serie_200 = $record->get_subfield($cle, 'h', 'i');
                 break;
             case "205":
                 /* mention_edition */
                 $subfield = $record->get_subfield($cle, "a");
                 $this->mention_edition = $subfield[0];
                 break;
             case "210":
                 /* publisher */
                 $editeur_lieu = $record->get_subfield_array_array($cle, "a");
                 $editeur_nom = $record->get_subfield_array_array($cle, "c");
                 $editeur_date = $record->get_subfield_array($cle, "d");
                 $editeur_date_machine = $record->get_subfield_array($cle, "h");
                 break;
             case "215":
                 /* description */
                 $subfield = $record->get_subfield($cle, "a");
                 $this->page_nbr = $subfield[0];
                 $subfield = $record->get_subfield($cle, "c");
                 $this->illustration = $subfield[0];
                 $subfield = $record->get_subfield($cle, "d");
                 $this->size = $subfield[0];
                 $subfield = $record->get_subfield($cle, "e");
                 $this->accompagnement = $subfield[0];
                 break;
             case "225":
                 /* collection */
                 $collection_225 = $record->get_subfield($cle, "a", "i", "v", "x");
                 break;
             case "300":
                 /* inside */
                 $general_note = $record->get_subfield($cle, "a");
                 break;
             case "327":
                 /* inside */
                 $content_note = $record->get_subfield_array($cle, "a");
                 break;
             case "330":
                 /* abstract */
                 $abstract_note = $record->get_subfield($cle, "a");
                 break;
             case "345":
                 /* EAN */
                 $EAN = $record->get_subfield($cle, "b");
                 break;
             case "410":
                 /* collection */
                 $collection_410 = $record->get_subfield($cle, "t", "v", "x");
                 break;
             case "411":
                 /* sub-collection */
                 $collection_411 = $record->get_subfield($cle, "t", "v", "x");
                 break;
             case "461":
                 /* series ou perios*/
                 if (($this->bibliographic_level == 'a' || $this->bibliographic_level == 'b' || $this->bibliographic_level == 's') && $this->hierarchic_level == '2') {
                     $perio = $record->get_subfield($cle, "t", "x", "v", "d", "e");
                     $this->perio_titre = $record->get_subfield_array($cle, "t");
                     $this->perio_issn = $record->get_subfield_array($cle, "x");
                     if ($record->get_subfield_array($cle, "v")) {
                         $this->bull_num = $record->get_subfield_array($cle, "v");
                     }
                     if ($record->get_subfield_array($cle, "d")) {
                         $this->bull_date = $record->get_subfield_array($cle, "d");
                     }
                     if ($record->get_subfield_array($cle, "e")) {
                         $this->bull_mention = $record->get_subfield_array($cle, "e");
                     }
                 } else {
                     $serie = $record->get_subfield($cle, "t", "v");
                 }
                 break;
             case "463":
                 /* Bulletins */
                 $bulletin_463 = $record->get_subfield($cle, "t", "v", "d", "e");
                 $this->bull_num = $record->get_subfield_array($cle, "v");
                 $this->bull_date = $record->get_subfield_array($cle, "d");
                 $this->bull_mention = $record->get_subfield_array($cle, "e");
                 $this->bull_titre = $record->get_subfield_array($cle, "t");
                 break;
             case "500":
                 /* Titres uniformes */
                 $this->tu_500 = $record->get_subfield($cle, "a", "k", "m", "q", "u", "v", "w");
                 $this->tu_500_i = $record->get_subfield_array_array($cle, "i");
                 $this->tu_500_j = $record->get_subfield_array_array($cle, "j");
                 $this->tu_500_l = $record->get_subfield_array_array($cle, "l");
                 $this->tu_500_n = $record->get_subfield_array_array($cle, "n");
                 $this->tu_500_r = $record->get_subfield_array_array($cle, "r");
                 $this->tu_500_s = $record->get_subfield_array_array($cle, "s");
                 break;
             case "503":
                 /* Titres de forme */
                 $this->info_503 = $record->get_subfield($cle, "a", "e", "f", "h", "m", "n");
                 $this->info_503_d = $record->get_subfield_array_array($cle, "d");
                 $this->info_503_j = $record->get_subfield_array_array($cle, "j");
                 break;
             case "530":
                 $perio530a = $record->get_subfield_array($cle, 'a');
                 break;
                 //TODO AR
                 //recup 530 (voir import_unimarc_lien)
             //TODO AR
             //recup 530 (voir import_unimarc_lien)
             case "600":
                 // 600 PERSONAL NAME USED AS SUBJECT
                 $this->info_600_3 = $record->get_subfield_array_array($cle, "3");
                 $this->info_600_a = $record->get_subfield_array_array($cle, "a");
                 $this->info_600_b = $record->get_subfield_array_array($cle, "b");
                 $this->info_600_c = $record->get_subfield_array_array($cle, "c");
                 $this->info_600_d = $record->get_subfield_array_array($cle, "d");
                 $this->info_600_f = $record->get_subfield_array_array($cle, "f");
                 $this->info_600_g = $record->get_subfield_array_array($cle, "g");
                 $this->info_600_j = $record->get_subfield_array_array($cle, "j");
                 $this->info_600_p = $record->get_subfield_array_array($cle, "p");
                 $this->info_600_t = $record->get_subfield_array_array($cle, "t");
                 $this->info_600_x = $record->get_subfield_array_array($cle, "x");
                 $this->info_600_y = $record->get_subfield_array_array($cle, "y");
                 $this->info_600_z = $record->get_subfield_array_array($cle, "z");
                 break;
             case "601":
                 // 601 CORPORATE BODY NAME USED AS SUBJECT
                 $this->info_601_3 = $record->get_subfield_array_array($cle, "3");
                 $this->info_601_a = $record->get_subfield_array_array($cle, "a");
                 $this->info_601_b = $record->get_subfield_array_array($cle, "b");
                 $this->info_601_c = $record->get_subfield_array_array($cle, "c");
                 $this->info_601_d = $record->get_subfield_array_array($cle, "d");
                 $this->info_601_e = $record->get_subfield_array_array($cle, "e");
                 $this->info_601_f = $record->get_subfield_array_array($cle, "f");
                 $this->info_601_g = $record->get_subfield_array_array($cle, "g");
                 $this->info_601_h = $record->get_subfield_array_array($cle, "h");
                 $this->info_601_t = $record->get_subfield_array_array($cle, "t");
                 $this->info_601_j = $record->get_subfield_array_array($cle, "j");
                 $this->info_601_x = $record->get_subfield_array_array($cle, "x");
                 $this->info_601_y = $record->get_subfield_array_array($cle, "y");
                 $this->info_601_z = $record->get_subfield_array_array($cle, "z");
                 break;
             case "602":
                 // 602 FAMILY NAME USED AS SUBJECT
                 $this->info_602_3 = $record->get_subfield_array_array($cle, "3");
                 $this->info_602_a = $record->get_subfield_array_array($cle, "a");
                 $this->info_602_f = $record->get_subfield_array_array($cle, "f");
                 $this->info_602_t = $record->get_subfield_array_array($cle, "t");
                 $this->info_602_j = $record->get_subfield_array_array($cle, "j");
                 $this->info_602_x = $record->get_subfield_array_array($cle, "x");
                 $this->info_602_y = $record->get_subfield_array_array($cle, "y");
                 $this->info_602_z = $record->get_subfield_array_array($cle, "z");
                 break;
             case "604":
                 // 604 AUTEUR-TITRE USED AS SUBJECT
                 $this->info_604_a = $record->get_subfield_array_array($cle, "a");
                 $this->info_604_h = $record->get_subfield_array_array($cle, "h");
                 $this->info_604_i = $record->get_subfield_array_array($cle, "i");
                 $this->info_604_j = $record->get_subfield_array_array($cle, "j");
                 $this->info_604_k = $record->get_subfield_array_array($cle, "k");
                 $this->info_604_l = $record->get_subfield_array_array($cle, "l");
                 $this->info_604_x = $record->get_subfield_array_array($cle, "x");
                 $this->info_604_y = $record->get_subfield_array_array($cle, "y");
                 $this->info_604_z = $record->get_subfield_array_array($cle, "z");
                 break;
             case "605":
                 // 605 TITLE USED AS SUBJECT
                 $this->info_605_3 = $record->get_subfield_array_array($cle, "3");
                 $this->info_605_a = $record->get_subfield_array_array($cle, "a");
                 $this->info_605_h = $record->get_subfield_array_array($cle, "h");
                 $this->info_605_i = $record->get_subfield_array_array($cle, "i");
                 $this->info_605_j = $record->get_subfield_array_array($cle, "j");
                 $this->info_605_k = $record->get_subfield_array_array($cle, "k");
                 $this->info_605_l = $record->get_subfield_array_array($cle, "l");
                 $this->info_605_m = $record->get_subfield_array_array($cle, "m");
                 $this->info_605_n = $record->get_subfield_array_array($cle, "n");
                 $this->info_605_q = $record->get_subfield_array_array($cle, "q");
                 $this->info_605_r = $record->get_subfield_array_array($cle, "r");
                 $this->info_605_s = $record->get_subfield_array_array($cle, "s");
                 $this->info_605_u = $record->get_subfield_array_array($cle, "u");
                 $this->info_605_w = $record->get_subfield_array_array($cle, "w");
                 $this->info_605_j = $record->get_subfield_array_array($cle, "j");
                 $this->info_605_x = $record->get_subfield_array_array($cle, "x");
                 $this->info_605_y = $record->get_subfield_array_array($cle, "y");
                 $this->info_605_z = $record->get_subfield_array_array($cle, "z");
                 break;
             case "606":
                 // RAMEAU / TOPICAL NAME USED AS SUBJECT
                 $this->info_606_3 = $record->get_subfield_array_array($cle, "3");
                 $this->info_606_a = $record->get_subfield_array_array($cle, "a");
                 $this->info_606_j = $record->get_subfield_array_array($cle, "j");
                 $this->info_606_x = $record->get_subfield_array_array($cle, "x");
                 $this->info_606_y = $record->get_subfield_array_array($cle, "y");
                 $this->info_606_z = $record->get_subfield_array_array($cle, "z");
                 break;
             case "607":
                 // 607 GEOGRAPHICAL NAME USED AS SUBJECT
                 $this->info_607_3 = $record->get_subfield_array_array($cle, "3");
                 $this->info_607_a = $record->get_subfield_array_array($cle, "a");
                 $this->info_607_j = $record->get_subfield_array_array($cle, "j");
                 $this->info_607_x = $record->get_subfield_array_array($cle, "x");
                 $this->info_607_y = $record->get_subfield_array_array($cle, "y");
                 $this->info_607_z = $record->get_subfield_array_array($cle, "z");
                 break;
             case "608":
                 // 608 Vedette matière de forme, de genre ou des caractéristiques physiques
                 $this->info_608_3 = $record->get_subfield_array_array($cle, "3");
                 $this->info_608_a = $record->get_subfield_array_array($cle, "a");
                 $this->info_608_j = $record->get_subfield_array_array($cle, "j");
                 $this->info_608_x = $record->get_subfield_array_array($cle, "x");
                 $this->info_608_y = $record->get_subfield_array_array($cle, "y");
                 $this->info_608_z = $record->get_subfield_array_array($cle, "z");
                 break;
             case "610":
                 /* mots clé */
                 $index_sujets = $record->get_subfield($cle, "a");
                 break;
             case "676":
                 /* Dewey */
                 $this->dewey = $record->get_subfield($cle, "a");
                 break;
             case "686":
                 /* PCDM */
                 if (!$this->dewey) {
                     $this->dewey = $record->get_subfield($cle, "a");
                 }
                 break;
             case "700":
                 $aut_700 = $record->get_subfield($cle, "a", "b", "c", "d", "4", "f", "N", "3");
                 break;
             case "701":
                 $aut_701 = $record->get_subfield($cle, "a", "b", "c", "d", "4", "f", "N", "3");
                 break;
             case "702":
                 $aut_702 = $record->get_subfield($cle, "a", "b", "c", "d", "4", "f", "N", "3");
                 break;
             case "710":
                 $aut_710 = $record->get_subfield($cle, "a", "b", "c", "g", "d", "4", "f", "e", "k", "l", "m", "n", "3");
                 break;
             case "711":
                 $aut_711 = $record->get_subfield($cle, "a", "b", "c", "g", "d", "4", "f", "e", "k", "l", "m", "n", "3");
                 break;
             case "712":
                 $aut_712 = $record->get_subfield($cle, "a", "b", "c", "g", "d", "4", "f", "e", "k", "l", "m", "n", "3");
                 break;
             case "801":
                 /* origine du catalogage */
                 $origine_notice = $record->get_subfield($cle, "a", "b");
                 break;
             case "856":
                 $ressource = $record->get_subfield($cle, "u", "q");
                 break;
             case "995":
                 /* infos de la BDP */
                 $info_995 = $record->get_subfield($cle, "a", "b", "c", "d", "f", "k", "m", "n", "o", "r", "u");
                 $this->exemplaires = $info_995;
                 break;
             case "896":
                 /* Thumbnail */
                 $this->thumbnail_url = $record->get_subfield($cle, "a");
                 $this->thumbnail_url = $this->thumbnail_url[0];
                 break;
                 //Documents numériques
             //Documents numériques
             case "897":
                 $this->doc_nums = $record->get_subfield($cle, "a", "b", "f", "p");
                 break;
             default:
                 break;
         }
         /* end of switch */
     }
     /* end of for */
     //Récupération des catégories en lien avec le fichier xml
     category_auto::get_info_categ($record);
     $this->isbn = $this->process_isbn($isbn[0]);
     if (function_exists("traite_categories_from_unimarc")) {
         $this->categories = traite_categories_from_unimarc($this);
     }
     /* INSERT de la notice OK, on va traiter les auteurs
     		70# : personnal : type auteur 70                71# : collectivités : type auteur 71
     		1 seul en 700                                   idem pour les déclinaisons          
     		n en 701 n en 702
     		les 7#0 tombent en auteur principal : responsability_type = 0
     		les 7#1 tombent en autre auteur : responsability_type = 1
     		les 7#2 tombent en auteur secondaire : responsability_type = 2
     		*/
     $this->aut_array = array();
     /* on compte tout de suite le nbre d'enreg dans les répétables */
     $nb_repet_701 = sizeof($aut_701);
     $nb_repet_711 = sizeof($aut_711);
     $nb_repet_702 = sizeof($aut_702);
     $nb_repet_712 = sizeof($aut_712);
     /* renseignement de aut0 */
     if ($aut_700[0][a] != "") {
         /* auteur principal en 700 ? */
         $this->aut_array[] = array("entree" => $aut_700[0]['a'], "rejete" => $aut_700[0]['b'], "author_comment" => $aut_700[0]['c'] . " " . $aut_700[0]['d'], "date" => $aut_700[0]['f'], "type_auteur" => "70", "fonction" => $aut_700[0][4], "id" => 0, "responsabilite" => 0, "ordre" => 0, "authority_number" => $aut_700[0][3]);
     } elseif ($aut_710[0]['a'] != "") {
         /* auteur principal en 710 ? */
         if (substr($indicateur["710"][0], 0, 1) == "1") {
             $type_auteur = "72";
         } else {
             $type_auteur = "71";
         }
         $lieu = $aut_710[0]['e'];
         if (!$lieu) {
             $lieu = $aut_710[0]['k'];
         }
         $this->aut_array[] = array("entree" => $aut_710[0]['a'], "rejete" => $aut_710[0]['g'], "subdivision" => $aut_710[0]['b'], "author_comment" => $aut_710[0]['c'], "numero" => $aut_710[0]['d'], "ville" => $aut_710[0]['l'], "web" => $aut_710[0]['n'], "date" => $aut_710[0]['f'], "type_auteur" => $type_auteur * 1, "fonction" => $aut_710[0][4], "id" => 0, "responsabilite" => 0, "ordre" => 0, "lieu" => $lieu, "pays" => $aut_710[0]['m'], "authority_number" => $aut_710[0][3]);
     }
     /* renseignement de aut1 */
     for ($i = 0; $i < $nb_repet_701; $i++) {
         $this->aut_array[] = array("entree" => $aut_701[$i]['a'], "rejete" => $aut_701[$i]['b'], "author_comment" => $aut_701[$i]['c'] . " " . $aut_701[$i]['d'], "date" => $aut_701[$i]['f'], "type_auteur" => "70", "fonction" => $aut_701[$i][4], "id" => 0, "responsabilite" => 1, "ordre" => $i + 1, "authority_number" => $aut_701[$i][3]);
     }
     for ($i = 0; $i < $nb_repet_711; $i++) {
         if (substr($indicateur["711"][$i], 0, 1) == "1") {
             $type_auteur = "72";
         } else {
             $type_auteur = "71";
         }
         $lieu = $aut_711[$i]['e'];
         if (!$lieu) {
             $lieu = $aut_711[$i]['k'];
         }
         $this->aut_array[] = array("entree" => $aut_711[$i]['a'], "rejete" => $aut_711[$i]['g'], "subdivision" => $aut_711[$i]['b'], "author_comment" => $aut_711[$i]['c'], "numero" => $aut_711[$i]['d'], "ville" => $aut_711[$i]['l'], "web" => $aut_711[$i]['n'], "date" => $aut_711[$i]['f'], "type_auteur" => $type_auteur * 1, "fonction" => $aut_711[$i][4], "id" => 0, "responsabilite" => 1, "lieu" => $lieu, "pays" => $aut_711[$i]['m'], "ordre" => $i + 1, "authority_number" => $aut_711[$i][3]);
     }
     /* renseignement de aut2 */
     for ($i = 0; $i < $nb_repet_702; $i++) {
         $this->aut_array[] = array("entree" => $aut_702[$i]['a'], "rejete" => $aut_702[$i]['b'], "author_comment" => $aut_702[$i]['c'] . " " . $aut_702[$i]['d'], "date" => $aut_702[$i]['f'], "type_auteur" => "70", "fonction" => $aut_702[$i][4], "id" => 0, "responsabilite" => 2, "ordre" => $i + 1, "authority_number" => $aut_702[$i][3]);
     }
     for ($i = 0; $i < $nb_repet_712; $i++) {
         if (substr($indicateur["712"][$i], 0, 1) == "1") {
             $type_auteur = "72";
         } else {
             $type_auteur = "71";
         }
         $lieu = $aut_712[$i]['e'];
         if (!$lieu) {
             $lieu = $aut_712[$i]['k'];
         }
         $this->aut_array[] = array("entree" => $aut_712[$i]['a'], "rejete" => $aut_712[$i]['g'], "subdivision" => $aut_712[$i]['b'], "author_comment" => $aut_712[$i]['c'], "numero" => $aut_712[$i]['d'], "ville" => $aut_712[$i]['l'], "web" => $aut_712[$i]['n'], "date" => $aut_712[$i]['f'], "type_auteur" => $type_auteur * 1, "fonction" => $aut_712[$i][4], "id" => 0, "responsabilite" => 2, "lieu" => $lieu, "pays" => $aut_712[$i]['m'], "ordre" => $i + 1, "authority_number" => $aut_712[$i][3]);
     }
     /*  Added for some italian z39.50 server 
     		Some adjustment to clean the values from symbol like << and others */
     for ($i = 0; $i < $nb_repet_701 + $nb_repet_711 + $nb_repet_702 + $nb_repet_712 + 1; $i++) {
         $this->aut_array[$i]['entree'] = del_more_garbage($this->aut_array[$i]['entree']);
         $this->aut_array[$i]['rejete'] = del_more_garbage($this->aut_array[$i]['rejete']);
     }
     /* traitement des éditeurs */
     $editor = array();
     if (is_array($editeur_nom)) {
         foreach ($editeur_nom as $key_nom1 => $nom1) {
             foreach ($nom1 as $key_nom2 => $nom2) {
                 $mon_ed = array();
                 $mon_ed["c"] = $nom2;
                 if ($editeur_lieu[$key_nom1][$key_nom2]) {
                     $mon_ed["a"] = $editeur_lieu[$key_nom1][$key_nom2];
                 }
                 $editor[] = $mon_ed;
             }
         }
     }
     $this->year = clean_string($editeur_date[0]);
     $this->editors[0]['name'] = clean_string($editor[0][c]);
     $this->editors[0]['ville'] = clean_string($editor[0][a]);
     $this->editors[1]['name'] = clean_string($editor[1][c]);
     $this->editors[1]['ville'] = clean_string($editor[1][a]);
     /*  Added for some italian z39.50 server 
     		Some adjustment to clean the values from symbol like << and others */
     $this->editors[0]['name'] = del_more_garbage($this->editors[0]['name']);
     $this->editors[1]['name'] = del_more_garbage($this->editors[1]['name']);
     /* traitement des collections */
     $coll_name = "";
     $subcoll_name = "";
     $coll_issn = "";
     $subcoll_issn = "";
     $nocoll_ins = "";
     // Collection : traitement de 225 et 410, préférence donnée au 410
     if ($collection_410[0][t]) {
         $coll_name = $collection_410[0][t];
     } elseif ($collection_225[0][a] != "") {
         $coll_name = $collection_225[0][a];
     }
     if ($collection_410[0][x]) {
         $coll_issn = $collection_410[0][x];
     } elseif ($collection_225[0][x] != "") {
         $coll_issn = $collection_225[0][x];
     }
     // Sous-collection : traitement de 225$i et 411, préférence donnée au 411
     if ($collection_411[0][t]) {
         $subcoll_name = $collection_411[0][t];
     } elseif ($collection_225[0][i] != "") {
         $subcoll_name = $collection_225[0][i];
     }
     if ($collection_411[0][x]) {
         $subcoll_issn = $collection_411[0][x];
     }
     // Numéro dans la collection, présent en 411$v, sinon en 410$v et enfin en 225$v
     if ($collection_411[0][v] != "") {
         $this->nbr_in_collection = $collection_411[0][v];
     } elseif ($collection_410[0][v] != "") {
         $this->nbr_in_collection = $collection_410[0][v];
     } elseif ($collection_225[0][v] != "") {
         $this->nbr_in_collection = $collection_225[0][v];
     } else {
         $this->nbr_in_collection = "";
     }
     $this->collection['name'] = clean_string($coll_name);
     $this->collection['issn'] = clean_string($coll_issn);
     $this->subcollection['name'] = clean_string($subcoll_name);
     $this->subcollection['issn'] = clean_string($subcoll_issn);
     /*  Added for some italian z39.50 server 
     		Some adjustment to clean the values from symbol like << and others */
     $this->collection['name'] = del_more_garbage($this->collection['name']);
     $this->subcollection['name'] = del_more_garbage($this->subcollection['name']);
     //TODO AR
     //nettoyage si notice de bulletin (voir import_unimarc_lien)
     //TEST si perio_titre vide -> recup 530
     if ($this->bibliographic_level == "s" && $this->hierarchic_level == "2") {
         if (!$this->perio_titre && $perio530a) {
             $this->perio_titre = $perio530a;
         }
         if (!$this->bull_titre && $tit_200a) {
             $this->bull_titre = array(clean_string($tit_200a[0]));
         }
         //file_put_contents('php://stderr', print_r($tit_200a[0], true));
         if (!$this->bull_num && $this->serie_200) {
             $this->bull_num = array(clean_string($this->serie_200[0]['h']));
         }
         if (!$this->bull_date && $editeur_date_machine) {
             $this->bull_date = array($editeur_date_machine[0]);
         }
         if (!$this->bull_mention && $editeur_date) {
             $this->bull_mention = array(clean_string($editeur_date[0]));
         }
         //file_put_contents('php://stderr', print_r($this->bull_mention, true));
         //file_put_contents('php://stderr', print_r($this->bull_date, true));
         $this->serie_200 = array();
     }
     /* Series  TODO: Check if it's Ok */
     $this->serie = clean_string($serie[0]['t']);
     if ($this->serie) {
         $this->nbr_in_serie = $serie[0]['v'];
     } else {
         $this->serie = clean_string($this->serie_200[0]['i']);
         if ($this->serie) {
             $this->nbr_in_serie = $this->serie_200[0]['h'];
         } else {
             $this->nbr_in_serie = "";
         }
     }
     /* Traitement des notes */
     $this->general_note = "";
     $this->content_note = "";
     $this->abstract_note = "";
     if (!$abstract_note) {
         $abstract_note = array();
     }
     $this->abstract_note = implode("\n", $abstract_note);
     if (!$general_note) {
         $general_note = array();
     }
     $this->general_note = implode("\n", $general_note);
     if (!$content_note) {
         $content_note = array();
     }
     $this->content_note = implode("\n", $content_note);
     /* traitement ressources */
     $this->link_url = $ressource[0]["u"];
     $this->link_format = $ressource[0]["q"];
     /* Titles processing */
     if (!$tit_200a) {
         $tit_200a = array();
     }
     if (!$tit_200c) {
         $tit_200c = array();
     }
     if (!$tit_200d) {
         $tit_200d = array();
     }
     if (!$tit_200e) {
         $tit_200e = array();
     }
     $tit[0]['a'] = implode(" ; ", $tit_200a);
     $tit[0]['c'] = implode(" ; ", $tit_200c);
     $tit[0]['d'] = implode(" ; ", $tit_200d);
     $tit[0]['e'] = implode(" ; ", $tit_200e);
     $this->titles[0] = clean_string($tit[0][a]);
     $this->titles[1] = clean_string($tit[0][c]);
     $this->titles[2] = clean_string($tit[0][d]);
     $this->titles[3] = clean_string($tit[0][e]);
     /*  Added for some italian z39.50 server 
     		Some adjustment to clean the values from symbol like << and others */
     $this->titles[0] = del_more_garbage($this->titles[0]);
     $this->titles[1] = del_more_garbage($this->titles[1]);
     $this->titles[2] = del_more_garbage($this->titles[2]);
     $this->titles[3] = del_more_garbage($this->titles[3]);
     global $pmb_keyword_sep;
     if (!$pmb_keyword_sep) {
         $pmb_keyword_sep = " ";
     }
     if (is_array($index_sujets)) {
         $this->free_index = implode($pmb_keyword_sep, $index_sujets);
     } else {
         $this->free_index = $index_sujets;
     }
     $this->origine_notice['nom'] = clean_string($origine_notice[0]['b']);
     $this->origine_notice['pays'] = clean_string($origine_notice[0]['a']);
 }
Example #2
0
function recup_noticeunimarc($notice)
{
    global $id_unimarc;
    global $doc_type;
    global $hierarchic_level;
    global $bibliographic_level;
    global $bibliographic_level_origine;
    global $hierarchic_level_origine;
    global $isbn;
    global $issn_011;
    global $prix;
    global $prix_cd;
    global $cb;
    global $lang_code;
    global $org_lang_code;
    global $tit_200a;
    global $tit_200c;
    global $tit_200d;
    global $tit_200e;
    global $tit_200v;
    global $serie_200;
    global $editeur_lieu;
    global $editeur_adr;
    global $editeur_nom;
    global $editeur_date;
    global $editeur_pays;
    global $editeur_pmbfields;
    global $no_edition;
    global $npages;
    global $ill;
    global $size;
    global $accomp;
    global $collection_225;
    global $n_contenu;
    global $n_resume;
    global $n_gen;
    global $EAN;
    global $collection_410;
    global $collection_411;
    global $serie;
    global $index_sujets;
    global $dewey;
    global $dewey_l;
    global $tu_500;
    global $tu_500_r;
    global $tu_500_s;
    global $tu_500_j;
    global $aut_700;
    global $aut_701;
    global $aut_702;
    global $aut_710;
    global $aut_711;
    global $aut_712;
    global $origine_notice;
    global $lien, $eformat;
    global $info_995;
    global $info_996;
    global $info_852;
    global $analytique;
    global $info_600_a, $info_600_j, $info_600_x, $info_600_y, $info_600_z;
    global $info_601_a, $info_601_j, $info_601_x, $info_601_y, $info_601_z;
    global $info_602_a, $info_602_j, $info_602_x, $info_602_y, $info_602_z;
    global $info_605_a, $info_605_j, $info_605_x, $info_605_y, $info_605_z;
    global $info_606_a, $info_606_j, $info_606_x, $info_606_y, $info_606_z;
    global $info_607_a, $info_607_j, $info_607_x, $info_607_y, $info_607_z;
    global $info_686;
    global $indicateur;
    global $link_generate;
    $id_import = array();
    $id_unimarc = 0;
    $indicateur = array();
    $doc_type = "";
    $hierarchic_level = '0';
    $bibliographic_level = 'm';
    $isbn = array();
    $issn_011 = array();
    $prix = array();
    $prix_cd = array();
    $cb = "";
    $lang_code = array();
    $org_lang_code = array();
    $tit_200a = array();
    $tit_200c = array();
    $tit_200d = array();
    $tit_200e = array();
    $tit_200v = array();
    $serie_200 = array();
    $editeur_lieu = array();
    $editeur_adr = array();
    $editeur_nom = array();
    $editeur_date = array();
    $editeur_pays = array();
    $editeur_pmbfields = array();
    $npages = array();
    $no_edition = array();
    $ill = array();
    $size = array();
    $accomp = array();
    $collection_225 = array();
    $collection_410 = array();
    $collection_411 = array();
    $n_contenu = array();
    $n_resume = array();
    $n_gen = array();
    $EAN = array();
    $serie = array();
    $index_sujets = array();
    $dewey = array();
    $dewey_l = array();
    $tu_500 = array();
    $tu_500_r = array();
    $tu_500_s = array();
    $tu_500_j = array();
    $aut_700 = array();
    $aut_701 = array();
    $aut_702 = array();
    $aut_710 = array();
    $aut_711 = array();
    $aut_712 = array();
    $origine_notice = array();
    $lien = array();
    $eformat = array();
    $info_995 = array();
    $info_852 = array();
    $analytique = array();
    $info_600_a = array();
    $info_600_j = array();
    $info_600_x = array();
    $info_600_y = array();
    $info_600_z = array();
    $info_601_a = array();
    $info_601_j = array();
    $info_601_x = array();
    $info_601_y = array();
    $info_601_z = array();
    $info_602_a = array();
    $info_602_j = array();
    $info_602_x = array();
    $info_602_y = array();
    $info_602_z = array();
    $info_605_a = array();
    $info_605_j = array();
    $info_605_x = array();
    $info_605_y = array();
    $info_605_z = array();
    $info_606_a = array();
    $info_606_j = array();
    $info_606_x = array();
    $info_606_y = array();
    $info_606_z = array();
    $info_607_a = array();
    $info_607_j = array();
    $info_607_x = array();
    $info_607_y = array();
    $info_607_z = array();
    $info_686 = array();
    $info_996 = array();
    $record = new iso2709_record($notice, AUTO_UPDATE);
    if (!$record->valid("import_notice")) {
        // On ne traite pas les notices invalides
        /*echo "<pre>";
        		print_r($record->inner_data);
        		echo "</pre>";
        		die();*/
        $num_notice = $record->get_subfield("001");
        $titr = $record->get_subfield_array("200", 'a');
        $requete = "insert into error_log(error_origin,error_text) values('import_func_" . addslashes(SESSid) . ".inc.php','" . addslashes("La notice (numéro : " . $num_notice[0] . ", titre : " . $titr[0] . ") n'a pas été reprise. <BR/><span style='color:#FF0000'>Erreur(s):" . implode("<BR/>", $record->errors) . "</span>") . "')";
        mysql_query($requete);
        return false;
    }
    $doc_type = $record->inner_guide['dt'];
    $bibliographic_level_origine = $record->inner_guide['bl'];
    $hierarchic_level_origine = $record->inner_guide['hl'];
    // traitements particuliers, solution d'urgence pour les pério et autres.
    if ($link_generate) {
        //Si on choisit d'importer les liens on reprend le niveau
        switch ($bibliographic_level_origine) {
            case 'a':
                $hierarchic_level = '2';
                $bibliographic_level = 'a';
                break;
            case 's':
                if ($hierarchic_level_origine <= '1') {
                    $hierarchic_level = '1';
                    $bibliographic_level = 's';
                } else {
                    $hierarchic_level = '2';
                    $bibliographic_level = 'b';
                }
                break;
            case 'm':
            case 'c':
            default:
                // suite à pb d'export Orphée : si inconnu, non conforme, on force à 0 et m
                $hierarchic_level = '0';
                $bibliographic_level = 'm';
                break;
        }
    } else {
        //Sinon on reprend tous en temps que monographie
        $hierarchic_level = '0';
        $bibliographic_level = 'm';
    }
    for ($i = 0; $i < count($record->inner_directory); $i++) {
        $cle = $record->inner_directory[$i]['label'];
        //$length=$record->inner_directory[$i]['length'];
        //$adress=$record->inner_directory[$i]['adress'];
        $flag_cle = 0;
        if (!array_key_exists($cle, $indicateur)) {
            $flag_cle = 1;
        }
        // memo indicateur de champ
        $indicateur[$cle][] = substr($record->inner_data[$i]['content'], 0, 2);
        if ($flag_cle) {
            switch ($cle) {
                case "001":
                    $id_import = $record->get_subfield($cle);
                    $id_unimarc = $id_import[0];
                    break;
                case "010":
                    /* isbn */
                    $isbn = $record->get_subfield($cle, 'a');
                    $prix = $record->get_subfield($cle, 'd');
                    break;
                case "011":
                    /* issn_011 */
                    $issn_011 = $record->get_subfield($cle, 'a');
                    break;
                case "071":
                    /* barcode */
                    $cb = $record->get_subfield($cle, "a");
                    break;
                case "101":
                    /* language */
                    $lang_code = $record->get_subfield_array($cle, "a");
                    $org_lang_code = $record->get_subfield_array($cle, "c");
                    break;
                case "200":
                    /* titles */
                    $tit_200a = $record->get_subfield_array($cle, 'a');
                    $tit_200c = $record->get_subfield_array($cle, 'c');
                    $tit_200d = $record->get_subfield_array($cle, 'd');
                    $tit_200e = $record->get_subfield_array($cle, 'e');
                    $tit_200v = $record->get_subfield_array($cle, 'v');
                    $serie_200 = $record->get_subfield($cle, "h", "i");
                    break;
                case "205":
                    /* no_edition */
                    $no_edition = $record->get_subfield_array($cle, "a");
                    break;
                case "210":
                    /* publisher */
                    // b: adr
                    $editeur_lieu = $record->get_subfield_array_array($cle, "a");
                    $editeur_adr = $record->get_subfield_array_array($cle, "b");
                    $editeur_nom = $record->get_subfield_array_array($cle, "c");
                    $editeur_date = $record->get_subfield_array($cle, "d");
                    $editeur_pays = $record->get_subfield_array_array($cle, "z");
                    $editeur_pmbfields = $record->get_subfield_array_array($cle, "9");
                    break;
                case "215":
                    /* description */
                    $npages = $record->get_subfield_array($cle, "a");
                    $ill = $record->get_subfield_array($cle, "c");
                    $size = $record->get_subfield_array($cle, "d");
                    $accomp = $record->get_subfield_array($cle, "e");
                    break;
                case "225":
                    /* collection */
                    $collection_225 = $record->get_subfield($cle, "a", "i", "v", "x");
                    break;
                case "300":
                    /* inside */
                    $n_gen = $record->get_subfield_array($cle, "a");
                    break;
                case "327":
                    /* inside */
                    $n_contenu = $record->get_subfield_array($cle, "a");
                    break;
                case "330":
                    /* abstract */
                    $n_resume = $record->get_subfield_array($cle, "a");
                    break;
                case "345":
                    /* EAN */
                    $EAN = $record->get_subfield($cle, "b");
                    $prix_cd = $record->get_subfield($cle, "d");
                    break;
                case "410":
                    /* collection */
                    $collection_410 = $record->get_subfield($cle, "v", "t", "x", "3");
                    break;
                case "411":
                    /* sub-collection */
                    $collection_411 = $record->get_subfield($cle, "v", "t", "x", "3");
                    break;
                case "461":
                    /* series */
                    $serie = $record->get_subfield($cle, "t", "v");
                    break;
                case "464":
                    /* analytique */
                    // $a pour le tout-venant le reste pour les périodiques bretons ! C'est un periodique donc un depouillement ou une notice objet
                    $analytique = $record->get_subfield_array_array($cle);
                    $info_464 = $record->get_subfield($cle, "t", "v", "p", "d", "z", "e");
                    break;
                case "500":
                    // titres uniformes
                    $tu_500 = $record->get_subfield($cle, "a", "i", "k", "l", "m", "n", "q", "u", "w", "3");
                    $tu_500_r = $record->get_subfield_array_array($cle, "r");
                    $tu_500_s = $record->get_subfield_array_array($cle, "s");
                    $tu_500_j = $record->get_subfield_array_array($cle, "j");
                    break;
                case "600":
                    // 600 PERSONAL NAME USED AS SUBJECT
                    $info_600_a = $record->get_subfield_array_array($cle, "a");
                    $info_600_j = $record->get_subfield_array_array($cle, "j");
                    $info_600_x = $record->get_subfield_array_array($cle, "x");
                    $info_600_y = $record->get_subfield_array_array($cle, "y");
                    $info_600_z = $record->get_subfield_array_array($cle, "z");
                    break;
                case "601":
                    // 601 CORPORATE BODY NAME USED AS SUBJECT
                    $info_601_a = $record->get_subfield_array_array($cle, "a");
                    $info_601_j = $record->get_subfield_array_array($cle, "j");
                    $info_601_x = $record->get_subfield_array_array($cle, "x");
                    $info_601_y = $record->get_subfield_array_array($cle, "y");
                    $info_601_z = $record->get_subfield_array_array($cle, "z");
                    break;
                case "602":
                    // 602 FAMILY NAME USED AS SUBJECT
                    $info_602_a = $record->get_subfield_array_array($cle, "a");
                    $info_602_j = $record->get_subfield_array_array($cle, "j");
                    $info_602_x = $record->get_subfield_array_array($cle, "x");
                    $info_602_y = $record->get_subfield_array_array($cle, "y");
                    $info_602_z = $record->get_subfield_array_array($cle, "z");
                    break;
                case "605":
                    // 605 TITLE USED AS SUBJECT
                    $info_605_a = $record->get_subfield_array_array($cle, "a");
                    $info_605_j = $record->get_subfield_array_array($cle, "j");
                    $info_605_x = $record->get_subfield_array_array($cle, "x");
                    $info_605_y = $record->get_subfield_array_array($cle, "y");
                    $info_605_z = $record->get_subfield_array_array($cle, "z");
                    break;
                case "606":
                    // RAMEAU / TOPICAL NAME USED AS SUBJECT
                    $info_606_a = $record->get_subfield_array_array($cle, "a");
                    $info_606_j = $record->get_subfield_array_array($cle, "j");
                    $info_606_x = $record->get_subfield_array_array($cle, "x");
                    $info_606_y = $record->get_subfield_array_array($cle, "y");
                    $info_606_z = $record->get_subfield_array_array($cle, "z");
                    break;
                case "607":
                    // 607 GEOGRAPHICAL NAME USED AS SUBJECT
                    $info_607_a = $record->get_subfield_array_array($cle, "a");
                    $info_607_j = $record->get_subfield_array_array($cle, "j");
                    $info_607_x = $record->get_subfield_array_array($cle, "x");
                    $info_607_y = $record->get_subfield_array_array($cle, "y");
                    $info_607_z = $record->get_subfield_array_array($cle, "z");
                    break;
                case "610":
                    /* mots clé */
                    $index_sujets = $record->get_subfield_array($cle, "a");
                    break;
                case "676":
                    /* Dewey */
                    $dewey = $record->get_subfield_array($cle, "a");
                    $dewey_l = $record->get_subfield_array($cle, "l");
                    $dewey_num = $record->get_subfield_array($cle, "l", "3");
                    break;
                case "686":
                    /* pcdm3 */
                    $info_686 = $record->get_subfield($cle, "a", "l", "3");
                    break;
                case "700":
                    $aut_700 = $record->get_subfield($cle, "a", "b", "c", "d", "4", "f", "N", "3");
                    break;
                case "701":
                    $aut_701 = $record->get_subfield($cle, "a", "b", "c", "d", "4", "f", "N", "3");
                    break;
                case "702":
                    $aut_702 = $record->get_subfield($cle, "a", "b", "c", "d", "4", "f", "N", "3");
                    break;
                case "710":
                    $aut_710 = $record->get_subfield($cle, "a", "b", "c", "g", "d", "4", "f", "e", "k", "l", "m", "n", "3");
                    break;
                case "711":
                    $aut_711 = $record->get_subfield($cle, "a", "b", "c", "g", "d", "4", "f", "e", "k", "l", "m", "n", "3");
                    break;
                case "712":
                    $aut_712 = $record->get_subfield($cle, "a", "b", "c", "g", "d", "4", "f", "e", "k", "l", "m", "n", "3");
                    break;
                case "801":
                    /* origine du catalogage */
                    $origine_notice = $record->get_subfield($cle, "a", "b");
                    break;
                case "852":
                    /* infos du SCD de Lyon 3 */
                    $info_852 = $record->get_subfield($cle, "b", "h", "p", "y");
                    break;
                case "856":
                    /* url */
                    $lien = $record->get_subfield($cle, "u");
                    $eformat = $record->get_subfield($cle, "q");
                    break;
                case "995":
                    /* infos de la BDP */
                    $info_995 = $record->get_subfield($cle, "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z", "0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "A", "B", "C", "D", "M", "N", "O", "P", "R", "S", "T", "U", "V", "W", "Z");
                    break;
                case "996":
                    /* infos supplémentaires... ? */
                    $info_996 = $record->get_subfield($cle, "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z", "0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "A", "B", "C", "D", "M", "N", "O", "P", "R", "S", "T", "U", "V", "W", "Z");
                    break;
                default:
                    break;
            }
            /* end of switch */
        }
    }
    /* end of for */
    //Récupération des catégories en lien avec le fichier xml
    category_auto::get_info_categ($record);
    return true;
}