Le fichier treetagger2xml.pl fourni a subi des modifications afin de correspondre à une structure particulière que je trouvais plus logique que celle de départ et pour que cela corresponde aux données que je possède. Dorénavant, il s'appelle tt2xml-art.pl.
#!/usr/bin/perl
use Unicode::String qw(utf8);
<<DOC;
Format d\'entree : un texte étiqueté et lemmatisé par tree tagger
Format de Sortie : le même texte au format xml (en utf-8)
DOC
# Usage
$ChaineUsage="Usage : tt2xml.pl <Fichier>\n";
if (@ARGV!=1) {
die $ChaineUsage;
}
&ouvre;
&entete;
&traitement;
&fin;
&ferme;
##############################################################################################
# Récupération des arguments et ouverture des tampons
sub ouvre {
$FichierEntree=$ARGV[0];
$encodage=$ARGV[1];
open(Entree,"<:encoding(utf-8)",$FichierEntree);
$FichierSortie=$FichierEntree . ".xml";
open(Sortie,">:encoding(utf-8)",$FichierSortie);
}
# Entête de document XML
sub entete {
print Sortie "<?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"no\"?>\n";
print Sortie "<document>\n";
print Sortie "<article>\n";
}
# Traitement
sub traitement {
while ($Ligne = <Entree>) {
if (uc($encodage) ne "UTF-8") {utf8($Ligne);}
if ($Ligne!~/\ô\¯\:\\ô\¯\:\\/) {
# Remplacement des guillemets par <![CDATA["]]> (évite erreur d'interprétation XML)
$Ligne=~s/\"/<![CDATA[\"]]>/g;
$Ligne=~s/([^\t]*)\t([^\t]*)\t(.*)/<element>\n <data type=\"type\">$2<\/data>\n <data type=\"lemma\">$3<\/data>\n <data type=\"string\">$1<\/data>\n<\/element>/;
$Ligne=~s/<unknown>/unknown/g;
print Sortie $Ligne;
}
}
}
# Fin de fichier
sub fin {
print Sortie "</article>\n";
print Sortie "</document>\n";
}
# Fermeture des tampons
sub ferme {
close(Entree);
close(Sortie);
}