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']); }
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; }