Skip to content
Extraits de code Groupes Projets
extract_rtf.php 1,24 ko
Newer Older
Fil's avatar
Fil a validé
<?php

//
// Lit un document 'rtf' et extrait son contenu en texte brut
//

// NOTE : l'extracteur n'est pas oblige de convertir le contenu dans
// le charset du site, mais il *doit* signaler le charset dans lequel
// il envoie le contenu, de facon a ce qu'il soit converti au moment
// voulu ; dans le cas contraire le document sera lu comme s'il etait
// dans le charset iso-8859-1

function extracteur_rtf($fichier, &$charset) {

	$charset = 'iso-8859-1';

	exec('metamail -d -q -b -c application/rtf '.escapeshellarg($fichier), $r, $e);
	if (!$e) return @join(' ', $r);
Fil's avatar
Fil a validé

	# wvText
	# http://wvware.sourceforge.net/
Fil's avatar
Fil a validé
	$temp = tempnam(_DIR_CACHE, 'rtf');
Fil's avatar
Fil a validé
	exec('wvText '.escapeshellarg($fichier).'> '.$temp, $r, $e);
	lire_fichier($temp, $contenu);
Fil's avatar
Fil a validé
	@unlink($temp);
Fil's avatar
Fil a validé
	if (!$e) return $contenu;


	# unrtf
	# http://www.gnu.org/software/unrtf/unrtf.html
	# --html car avec --text les accents sont perdus :(
	exec('unrtf --html '.escapeshellarg($fichier), $r, $e);
	if (!$e) return join(' ', $r);

	# catdoc
	# http://www.45.free.net/~vitus/ice/catdoc/
	exec('catdoc '.escapeshellarg($fichier), $r, $e);
	if (!$e) return join(' ', $r);

}

// Sait-on extraire ce format ?
// TODO: ici tester si les binaires fonctionnent
$GLOBALS['extracteur']['rtf'] = 'extracteur_rtf';

esj's avatar
 
esj a validé
?>