Subversion Repositories eFlore/Projets.eflore-projets

Rev

Rev 478 | Rev 493 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 478 Rev 487
1
<?php
1
<?php
2
class Index {
2
class Index {
3
 
3
 
4
	const DOSSIER_V0 = '../../../donnees/coste/0.00/';
4
	const DOSSIER_V0 = '../../../donnees/coste/0.00/';
5
	const DOSSIER_V2 = '../../../donnees/coste/2.00/';
5
	const DOSSIER_V2 = '../../../donnees/coste/2.00/';
6
 
6
 
7
	private $conteneur = null;
7
	private $conteneur = null;
8
	private $outils = null;
8
	private $outils = null;
9
	private $messages = null;
9
	private $messages = null;
-
 
10
	private $generateur = null;
10
	private $dossierBase = '';
11
	private $dossierBase = '';
11
	private $spIndex = array();
12
	private $spIndex = array();
12
	private $supraSpIndex = array();
13
	private $supraSpIndex = array();
-
 
14
	private $imgIndex = array();
13
	private $indexFinal = array();
15
	private $indexFinal = array();
14
	private $tableauParDefaut = array();
16
	private $tableauParDefaut = array();
15
	private $nbreTaxonInf = array();
17
	private $nbreTaxonInf = array();
16
	private $enteteFinal = array(
18
	private $enteteFinal = array(
17
		'num_nom',
19
		'num_nom',
18
		'num_nom_retenu',
20
		'num_nom_retenu',
19
		'num_tax_sup',
21
		'num_tax_sup',
20
		'rang',
22
		'rang',
21
		'nom_sci',
23
		'nom_sci',
-
 
24
		'nom_supra_generique',
-
 
25
		'genre',
-
 
26
		'epithete_infra_generique',
-
 
27
		'epithete_sp',
-
 
28
		'type_epithete',
-
 
29
		'epithete_infra_sp',
-
 
30
		'cultivar_groupe',
-
 
31
		'cultivar',
-
 
32
		'nom_commercial',
22
		'auteur',
33
		'auteur',
23
		'nom_addendum',
-
 
24
		'annee',
34
		'annee',
25
		'biblio_origine',
35
		'biblio_origine',
-
 
36
		'notes',
-
 
37
		'nom_addendum',
26
		'nom_francais',
38
		'nom_francais',
27
		'nom_coste',
39
		'nom_coste',
28
		'auteur_coste',
40
		'auteur_coste',
29
		'biblio_coste',
41
		'biblio_coste',
30
		'num_nom_coste',
42
		'num_nom_coste',
31
		'num_nom_retenu_coste',
43
		'num_nom_retenu_coste',
32
		'num_tax_sup_coste',
44
		'num_tax_sup_coste',
33
		'synonymie_coste',
45
		'synonymie_coste',
34
		'tome',
46
		'tome',
35
		'page',
47
		'page',
36
		'nbre_taxons',
48
		'nbre_taxons',
37
		'bdnff_nn',
49
		'flore_bdtfx_nn',
38
		'bdnff_nt',
50
		'flore_bdtfx_nt',
39
		'image',
51
		'image',
-
 
52
		'image_auteur',
40
		'page_wiki_dsc',
53
		'page_wiki_dsc',
41
		'page_wiki_cle');
54
		'page_wiki_cle',
-
 
55
		'nom_sci_html');
42
 
56
 
43
	public function __construct(Conteneur $conteneur) {
57
	public function __construct(Conteneur $conteneur) {
44
		mb_internal_encoding('UTF-8');
58
		mb_internal_encoding('UTF-8');
45
		setlocale(LC_ALL, 'fr_FR.UTF-8');
59
		setlocale(LC_ALL, 'fr_FR.UTF-8');
46
		$this->conteneur = $conteneur;
60
		$this->conteneur = $conteneur;
47
		$this->outils = $conteneur->getOutils();
61
		$this->outils = $conteneur->getOutils();
48
		$this->messages = $conteneur->getMessages();
62
		$this->messages = $conteneur->getMessages();
-
 
63
		$this->generateur = $conteneur->getGenerateurNomSciHtml();
49
		$this->dossierBase = dirname(__FILE__).'/';
64
		$this->dossierBase = dirname(__FILE__).'/';
50
	}
65
	}
51
 
66
 
52
	public function fusionnerIndex() {
67
	public function fusionnerIndex() {
53
		$this->chargerIndexSp();
68
		$this->chargerIndexSp();
54
		$this->chargerIndexSupraSp();
69
		$this->chargerIndexSupraSp();
55
		$this->initialiserTableauLigneIndexFinal();
70
		$this->initialiserTableauLigneIndexFinal();
56
		$this->creerIndexFinal();
71
		$this->creerIndexFinal();
57
		$this->ajouterChampsDansIndexFinal();
72
		$this->ajouterChampsDansIndexFinal();
-
 
73
		$this->ajouteurAuteurImage();
-
 
74
		$this->decomposerNomSci();
-
 
75
		$this->ajouteurNomSciHtml();
58
		$this->creerFichierCsvIndexFinal();
76
		$this->creerFichierCsvIndexFinal();
59
	}
77
	}
60
 
78
 
61
	private function chargerIndexSp() {
79
	private function chargerIndexSp() {
62
		$spIndexFichier = $this->dossierBase.self::DOSSIER_V0.'index_general_sp.tsv';
80
		$spIndexFichier = $this->dossierBase.self::DOSSIER_V0.'index_general_sp.tsv';
63
		$index = $this->outils->transformerTxtTsvEnTableau($spIndexFichier);
81
		$index = $this->outils->transformerTxtTsvEnTableau($spIndexFichier);
64
		$index = $this->reindexerParNumNomCoste($index);
82
		$index = $this->reindexerParNumNomCoste($index);
65
		foreach ($index as $numNomCoste => $infos) {
83
		foreach ($index as $numNomCoste => $infos) {
66
			$numTaxSup = '';
84
			$numTaxSup = '';
67
			if ($infos['num_nom_coste'] == $infos['num_nom_retenu_coste']) {
85
			if ($infos['num_nom_coste'] == $infos['num_nom_retenu_coste']) {
68
				$numTaxSup = $infos['num_tax_sup_coste'];
86
				$numTaxSup = $infos['num_tax_sup_coste'];
69
			} else {
87
			} else {
70
				$infosNomRetenu = $index[$infos['num_nom_retenu_coste']];
88
				$infosNomRetenu = $index[$infos['num_nom_retenu_coste']];
71
				$numTaxSup = $infosNomRetenu['num_tax_sup_coste'];
89
				$numTaxSup = $infosNomRetenu['num_tax_sup_coste'];
72
			}
90
			}
73
			$this->spIndex[$numTaxSup][] = $infos;
91
			$this->spIndex[$numTaxSup][] = $infos;
74
		}
92
		}
75
	}
93
	}
76
 
94
 
77
	private function reindexerParNumNomCoste($index) {
95
	private function reindexerParNumNomCoste($index) {
78
		$nouvelIndex = array();
96
		$nouvelIndex = array();
79
		foreach ($index as $infos) {
97
		foreach ($index as $infos) {
80
			$nouvelIndex[$infos['num_nom_coste']] = $infos;
98
			$nouvelIndex[$infos['num_nom_coste']] = $infos;
81
		}
99
		}
82
		return $nouvelIndex;
100
		return $nouvelIndex;
83
	}
101
	}
84
 
102
 
85
	private function chargerIndexSupraSp() {
103
	private function chargerIndexSupraSp() {
86
		$infraSpIndexFichier = $this->dossierBase.self::DOSSIER_V0.'index_general.tsv';
104
		$infraSpIndexFichier = $this->dossierBase.self::DOSSIER_V0.'index_general.tsv';
87
		$this->supraSpIndex = $this->outils->transformerTxtTsvEnTableau($infraSpIndexFichier);
105
		$this->supraSpIndex = $this->outils->transformerTxtTsvEnTableau($infraSpIndexFichier);
88
		foreach ($this->supraSpIndex as $cle => $infos) {
106
		foreach ($this->supraSpIndex as $cle => $infos) {
89
			$this->supraSpIndex[$cle]['num_nom_retenu_coste'] = $infos['num_nom_coste'];
107
			$this->supraSpIndex[$cle]['num_nom_retenu_coste'] = $infos['num_nom_coste'];
90
		}
108
		}
91
	}
109
	}
92
 
110
 
93
	private function initialiserTableauLigneIndexFinal() {
111
	private function initialiserTableauLigneIndexFinal() {
94
		$this->tableauParDefaut = array();
112
		$this->tableauParDefaut = array();
95
		foreach ($this->enteteFinal as $cle) {
113
		foreach ($this->enteteFinal as $cle) {
96
			$this->tableauParDefaut[$cle] = '';
114
			$this->tableauParDefaut[$cle] = '';
97
		}
115
		}
98
	}
116
	}
99
 
117
 
100
	private function creerIndexFinal() {
118
	private function creerIndexFinal() {
101
		foreach ($this->supraSpIndex as $infos) {
119
		foreach ($this->supraSpIndex as $infos) {
102
			$this->ajouterDansIndexFinal($infos);
120
			$this->ajouterDansIndexFinal($infos);
103
			if (preg_match('/^G[0-9]+$/', $infos['num_nom_coste'])) {
121
			if (preg_match('/^G[0-9]+$/', $infos['num_nom_coste'])) {
104
				foreach ($this->spIndex[$infos['num_nom_coste']] as $infosSp) {
122
				foreach ($this->spIndex[$infos['num_nom_coste']] as $infosSp) {
105
					$this->ajouterDansIndexFinal($infosSp);
123
					$this->ajouterDansIndexFinal($infosSp);
106
				}
124
				}
107
			}
125
			}
108
		}
126
		}
109
	}
127
	}
110
 
128
 
111
	private function ajouterDansIndexFinal($infos) {
129
	private function ajouterDansIndexFinal($infos) {
112
		$infos = array_merge($this->tableauParDefaut, $infos);
130
		$infos = array_merge($this->tableauParDefaut, $infos);
113
		$infos['num_nom'] = (count($this->indexFinal) + 1);
131
		$infos['num_nom'] = (count($this->indexFinal) + 1);
114
		$this->indexFinal[$infos['num_nom_coste']] = $infos;
132
		$this->indexFinal[$infos['num_nom_coste']] = $infos;
115
	}
133
	}
116
 
134
 
117
	private function ajouterChampsDansIndexFinal() {
135
	private function ajouterChampsDansIndexFinal() {
118
		$this->genererNbreTaxons();
136
		$this->genererNbreTaxons();
119
		foreach ($this->indexFinal as $nnc => $infos) {
137
		foreach ($this->indexFinal as $nnc => $infos) {
120
			if ($infos['num_nom_coste'] == $infos['num_nom_retenu_coste']) {
138
			if ($infos['num_nom_coste'] == $infos['num_nom_retenu_coste']) {
121
				$infos['num_nom_retenu'] = $infos['num_nom'];
139
				$infos['num_nom_retenu'] = $infos['num_nom'];
122
				if ($nnc != 'R') {
140
				if ($nnc != 'R') {
123
					$nomSuperieur = $this->indexFinal[$infos['num_tax_sup_coste']];
141
					$nomSuperieur = $this->indexFinal[$infos['num_tax_sup_coste']];
124
					$infos['num_tax_sup'] = $nomSuperieur['num_nom'];
142
					$infos['num_tax_sup'] = $nomSuperieur['num_nom'];
125
				}
143
				}
126
				$nomRetenu = $infos;
144
				$nomRetenu = $infos;
127
			} else {
145
			} else {
128
				$nomRetenu = $this->indexFinal[$infos['num_nom_retenu_coste']];
146
				$nomRetenu = $this->indexFinal[$infos['num_nom_retenu_coste']];
129
				$infos['num_nom_retenu'] = $nomRetenu['num_nom'];
147
				$infos['num_nom_retenu'] = $nomRetenu['num_nom'];
130
			}
148
			}
131
			$infos['image'] = $this->obtenirNomFichierImg($nomRetenu);
149
			$infos['image'] = $this->obtenirNomFichierImg($nomRetenu);
132
			$infos['nbre_taxons'] = $this->obtenirNbreTaxon($infos);
150
			$infos['nbre_taxons'] = $this->obtenirNbreTaxon($infos);
133
			$nomRetenu['nbre_taxons'] = $infos['nbre_taxons'];
151
			$nomRetenu['nbre_taxons'] = $infos['nbre_taxons'];
134
			$infos['page_wiki_dsc'] = $this->genererPageWikiDsc($nomRetenu);
152
			$infos['page_wiki_dsc'] = $this->genererPageWikiDsc($nomRetenu);
135
			$infos['page_wiki_cle'] = $this->genererPageWikiCle($nomRetenu);
153
			$infos['page_wiki_cle'] = $this->genererPageWikiCle($nomRetenu);
136
 
154
 
137
			$this->indexFinal[$nnc] = $infos;
155
			$this->indexFinal[$nnc] = $infos;
138
		}
156
		}
139
	}
157
	}
140
 
158
 
141
	private function genererNbreTaxons() {
159
	private function genererNbreTaxons() {
142
		foreach ($this->indexFinal as $infos) {
160
		foreach ($this->indexFinal as $infos) {
143
			if ($infos['num_tax_sup_coste'] != '') {
161
			if ($infos['num_tax_sup_coste'] != '') {
144
				if (isset($this->nbreTaxonInf[$infos['num_tax_sup_coste']])) {
162
				if (isset($this->nbreTaxonInf[$infos['num_tax_sup_coste']])) {
145
					$this->nbreTaxonInf[$infos['num_tax_sup_coste']] += 1;
163
					$this->nbreTaxonInf[$infos['num_tax_sup_coste']] += 1;
146
				} else {
164
				} else {
147
					$this->nbreTaxonInf[$infos['num_tax_sup_coste']] = 1;
165
					$this->nbreTaxonInf[$infos['num_tax_sup_coste']] = 1;
148
				}
166
				}
149
			}
167
			}
150
		}
168
		}
151
	}
169
	}
152
 
170
 
153
	private function genererPageWikiDsc($infos) {
171
	private function genererPageWikiDsc($infos) {
154
		$prefixe = $this->genererPrefixePage($infos);
172
		$prefixe = $this->genererPrefixePage($infos);
-
 
173
		if ($infos['rang'] == '180') {
-
 
174
			$nomSci = str_replace(' ', '', ucwords(strtolower($infos['nom_coste'])));
-
 
175
		} else {
155
		$nomSci = str_replace(' ', '', ucwords(strtolower($infos['nom_sci'])));
176
			$nomSci = str_replace(' ', '', ucwords(strtolower($infos['nom_sci'])));
-
 
177
		}
156
		$pageWiki = $prefixe.$nomSci;
178
		$pageWiki = $prefixe.$nomSci;
157
		return $pageWiki;
179
		return $pageWiki;
158
	}
180
	}
159
 
181
 
160
	private function genererPageWikiCle($infos) {
182
	private function genererPageWikiCle($infos) {
161
		$pageWiki = '';
183
		$pageWiki = '';
162
		if ($infos['nbre_taxons'] > 1) {
184
		if ($infos['nbre_taxons'] > 1) {
163
			$prefixe = $this->genererPrefixePage($infos);
185
			$prefixe = $this->genererPrefixePage($infos);
164
			if ($infos['rang'] == '180') {
186
			if ($infos['rang'] == '20') {
-
 
187
				$pageWiki = $prefixe.'TabClaEtEmb';
-
 
188
			} elseif ($infos['rang'] == '40' && ($infos['num_nom_coste'] == 'E2' || $infos['num_nom_coste'] == 'E3')) {
-
 
189
				$pageWiki = $prefixe.'TabFam';
-
 
190
			} else if ($infos['rang'] == '80') {
-
 
191
				$pageWiki = $prefixe.'TabFam';
-
 
192
			} else if ($infos['rang'] == '180') {
165
				$pageWiki = $prefixe.'TabGen';
193
				$pageWiki = $prefixe.'TabGen';
166
			} else if ($infos['rang'] == '220') {
194
			} else if ($infos['rang'] == '220') {
167
				$pageWiki = $prefixe.'TabSp';
195
				$pageWiki = $prefixe.'TabSp';
168
			}
196
			}
169
		}
197
		}
170
		return $pageWiki;
198
		return $pageWiki;
171
	}
199
	}
172
 
200
 
173
	private function genererPrefixePage($infos) {
201
	private function genererPrefixePage($infos) {
174
		$prefixe = '';
202
		$prefixe = '';
175
		$num = preg_replace('/^[a-z]*([0-9.]+)$/i', '$1', $infos['num_nom_coste']);
203
		$num = preg_replace('/^[a-z]*([0-9.]+)$/i', '$1', $infos['num_nom_coste']);
176
		if (preg_match('/^([0-9]+)[.][0-9]+$/i', $infos['num_nom_coste'], $match)) {
204
		if (preg_match('/^([0-9]+)[.][0-9]+$/i', $infos['num_nom_coste'], $match)) {
177
			$num = sprintf('%04s', $match[1]);
205
			$num = sprintf('%04s', $match[1]);
-
 
206
		} else if ($infos['rang'] == 20 ) {
-
 
207
			$num = '';
178
		} else if ($infos['rang'] < 80 ) {
208
		} else if ($infos['rang'] < 80 ) {
179
			$num = sprintf('%02s', $num);
209
			$num = sprintf('%02s', $num);
180
		} else if ($infos['rang'] < 290 ) {
210
		} else if ($infos['rang'] < 290 ) {
181
			$num = sprintf('%03s', $num);
211
			$num = sprintf('%03s', $num);
182
		} else {
212
		} else {
183
			$num = sprintf('%04s', $num);
213
			$num = sprintf('%04s', $num);
184
		}
214
		}
185
		$rangsTxt = array('20' => 'Reg', '40' => 'Emb', '80' => 'Cla', '180' => 'Fam', '220' => 'Gen', '290' => 'Esp', '340' => 'Var');
215
		$rangsTxt = array('20' => 'Reg', '40' => 'Emb', '80' => 'Cla', '180' => 'Fam', '220' => 'Gen', '290' => 'Esp', '340' => 'Var');
186
		$rang = $rangsTxt[$infos['rang']];
216
		$rang = $rangsTxt[$infos['rang']];
187
 
217
 
188
		$prefixe = $rang.$num;
218
		$prefixe = $rang.$num;
189
		return $prefixe;
219
		return $prefixe;
190
	}
220
	}
191
 
221
 
192
	private function obtenirNbreTaxon($infos) {
222
	private function obtenirNbreTaxon($infos) {
193
		$nbre = '';
223
		$nbre = '';
194
		if ($infos['rang'] == 180 || $infos['rang'] == 220) {
-
 
195
			if (isset($this->nbreTaxonInf[$infos['num_nom_coste']])) {
224
		if (isset($this->nbreTaxonInf[$infos['num_nom_coste']])) {
196
				$nbre = $this->nbreTaxonInf[$infos['num_nom_coste']];
225
			$nbre = $this->nbreTaxonInf[$infos['num_nom_coste']];
197
			}
-
 
198
		}
226
		}
199
		return $nbre;
227
		return $nbre;
200
	}
228
	}
201
 
229
 
202
	private function obtenirNomFichierImg($infos) {
230
	private function obtenirNomFichierImg($infos) {
203
		$img = '';
231
		$img = '';
204
		if ($infos['rang'] == '290' && ($infos['num_nom'] == $infos['num_nom_retenu'])) {
232
		if ($infos['rang'] == '290' && ($infos['num_nom'] == $infos['num_nom_retenu'])) {
205
			$img = $infos['num_nom_coste'].'.png';
233
			$img = $infos['num_nom_coste'].'.png';
206
		}
234
		}
207
		return $img;
235
		return $img;
208
	}
236
	}
-
 
237
 
-
 
238
	private function ajouteurAuteurImage() {
-
 
239
		$this->chargerAuteurImg();
-
 
240
		foreach ($this->indexFinal as $nnc => $infos) {
-
 
241
			$infos['image_auteur'] = $this->imgIndex[$infos['image']];
-
 
242
			$this->indexFinal[$nnc] = $infos;
-
 
243
		}
-
 
244
	}
-
 
245
 
-
 
246
	private function chargerAuteurImg() {
-
 
247
		$imgIndexFichier = $this->dossierBase.self::DOSSIER_V0.'coste_images_auteur_correspondance_bdnff.tsv';
-
 
248
		$index = $this->outils->transformerTxtTsvEnTableau($imgIndexFichier);
-
 
249
		foreach ($index as $infos) {
-
 
250
			$id = $infos['id_image'];
-
 
251
			$this->imgIndex[$id] = $infos['auteur'];
-
 
252
		}
-
 
253
	}
-
 
254
 
-
 
255
	private function decomposerNomSci() {
-
 
256
		$majuscule = "[ÆŒA-Z]";
-
 
257
		$epithete = "[æœïa-z-]+";
-
 
258
		foreach ($this->indexFinal as $nnc => $infos) {
-
 
259
			$id = $infos['num_nom_coste'];
-
 
260
			$nomSci = $infos['nom_sci'];
-
 
261
			$rang = $infos['rang'];
-
 
262
			if ($rang < 220) {
-
 
263
				$infos['nom_supra_generique'] = $nomSci;
-
 
264
			} else if ($rang == 220) {
-
 
265
				$infos['genre'] = $nomSci;
-
 
266
			} else if ($rang == 290) {
-
 
267
				if (preg_match("/^($majuscule$epithete) ($epithete)$/", $nomSci, $match)) {
-
 
268
					$infos['genre'] = $match[1];
-
 
269
					$infos['epithete_sp'] = $match[2];
-
 
270
				} else {
-
 
271
					$this->messages->traiterErreur("Le nom $nomSci ($id) de rang $rang n'est pas standard.");
-
 
272
				}
-
 
273
			} else if ($rang == 340) {
-
 
274
				if (preg_match("/^($majuscule$epithete) ($epithete) (var[.]) ($epithete)$/", $nomSci, $match)) {
-
 
275
					$infos['genre'] = $match[1];
-
 
276
					$infos['epithete_sp'] = $match[2];
-
 
277
					$infos['type_epithete'] = $match[3];
-
 
278
					$infos['epithete_infra_sp'] = $match[4];
-
 
279
				} else {
-
 
280
					$this->messages->traiterErreur("Le nom $nomSci ($id) de rang $rang n'est pas standard.");
-
 
281
				}
-
 
282
			}
-
 
283
 
-
 
284
			$this->indexFinal[$nnc] = $infos;
-
 
285
			$this->messages->afficherAvancement("Décomposition des noms scientifiques en cours");
-
 
286
		}
-
 
287
		echo "\n";
-
 
288
	}
-
 
289
 
-
 
290
	private function ajouteurNomSciHtml() {
-
 
291
		foreach ($this->indexFinal as $nnc => $infos) {
-
 
292
			$this->indexFinal[$nnc]['nom_sci_html'] = $this->generateur->genererNomSciHtml($infos);
-
 
293
			$this->messages->afficherAvancement("Création des noms scientifiques HTML en cours");
-
 
294
		}
-
 
295
		echo "\n";
-
 
296
	}
209
 
297
 
210
	private function creerFichierCsvIndexFinal() {
298
	private function creerFichierCsvIndexFinal() {
211
		$lignes = array();
299
		$lignes = array();
212
		array_unshift($this->indexFinal, $this->enteteFinal);
300
		array_unshift($this->indexFinal, $this->enteteFinal);
213
		foreach ($this->indexFinal as $infos) {
301
		foreach ($this->indexFinal as $infos) {
214
			$lignes[] = implode("\t", $infos);
302
			$lignes[] = implode("\t", $infos);
215
		}
303
		}
216
 
304
 
217
		$txt = '';
305
		$txt = '';
218
		$txt = implode("\n", $lignes);
306
		$txt = implode("\n", $lignes);
219
 
307
 
220
		$fichierTsvIndexFinal = $this->dossierBase.self::DOSSIER_V2.'coste_v2_00.tsv';
308
		$fichierTsvIndexFinal = $this->dossierBase.self::DOSSIER_V2.'coste_v2_00.tsv';
221
		file_put_contents($fichierTsvIndexFinal, $txt);
309
		file_put_contents($fichierTsvIndexFinal, $txt);
222
	}
310
	}
223
}
311
}
224
?>
312
?>