Problème script de recherche avec fichier

Résolu/Fermé
Utilisateur anonyme - Modifié le 22 août 2017 à 13:55
 Utilisateur anonyme - 22 août 2017 à 15:19
Bonjour, j'ai un script qui permet d'écrire un article et qui stocke son contenu dans un fichier, mais je n'arrive pas à voir comment je peux modifier mon ancien code pour qu'il recherche dans le fichier : (j'ai enlever la colonne 'contenu' de ma bdd)
$articleParPage = 5; 
    $articleTotalesReq = $bdd->prepare('SELECT * FROM article_articles WHERE verif = 1 AND CONCAT(titre, contenu) LIKE :queryString');
    $articleTotalesReq->execute(array(':queryString' => '%'.$q.'%'));
    $articleTotales = $articleTotalesReq->rowCount();
    $pagesTotales = ceil($articleTotales/$articleParPage);
    if(isset($_GET['page']) AND !empty($_GET['page']) AND intval($_GET['page']) > 0 AND $_GET['page'] <= $pagesTotales) {
        $_GET['page'] = intval($_GET['page']);
        $pageCourante = $_GET['page'];
    } else {
        $pageCourante = 1;
    }
    $depart = ($pageCourante-1)*$articleParPage;
    $articles = $bdd->prepare('SELECT * FROM article_articles WHERE titre AND verif = 1 LIKE CONCAT("%", :query, "%") ORDER BY id DESC LIMIT :debut, :nombre');
    $articles->bindParam(':debut', $depart, PDO::PARAM_INT);
    $articles->bindParam(':nombre', $articleParPage, PDO::PARAM_INT);
    $articles->bindParam(':query', $q, PDO::PARAM_STR);
    $articles->execute();
    if($articles->rowCount() == 0) {
        $articles = $bdd->prepare('SELECT * FROM article_articles WHERE verif = 1 AND CONCAT(titre, contenu) LIKE CONCAT("%", :query, "%") ORDER BY id DESC LIMIT :debut, :nombre');
        $articles->bindParam(':debut', $depart, PDO::PARAM_INT);
        $articles->bindParam(':nombre', $articleParPage, PDO::PARAM_INT);
        $articles->bindParam(':query', $q, PDO::PARAM_STR);
        $articles->execute();
    }

Juste pour info, les fichiers créés sont sous cette forme : article_numDeLarticle.txt
Merci d'avance
Nils0
A voir également:

1 réponse

jordane45 Messages postés 38350 Date d'inscription mercredi 22 octobre 2003 Statut Modérateur Dernière intervention 26 décembre 2024 4 719
22 août 2017 à 14:56
Bonjour,


pour qu'il recherche dans le fichier

Pour ça .. tu peux lire le fichier ligne par ligne jusqu'à trouver l'info cherchée
https://www.php.net/manual/fr/function.fgets.php

NB : EN PDO .. on place les requêtes dans des blocs TRY/CATCH pour intercepter les éventuelles erreurs
NB² : EN PDO .. on n'utilise pas ROWCOUNT avec une requête SELECT. A la place on fera un FETCHALL puis un COUT sur la variable

NB" : On récupère PROPREMENT les variables AVANT de les utiliser !
Par exemple :
    if(isset($_GET['page']) AND !empty($_GET['page']) AND intval($_GET['page']) > 0 AND $_GET['page'] <= $pagesTotales) {
        $_GET['page'] = intval($_GET['page']);
        $pageCourante = $_GET['page'];
    } else {
        $pageCourante = 1;
    }

S'écrit plus proprement :
 $pageCourante = !empty($_GET['page']) && intval($_GET['page'])>0 && intval($_GET['page'])<= $pagesTotales ? intval($_GET['page']) : 1;

0
Utilisateur anonyme
22 août 2017 à 15:01
merci de ta réponse, comme j'ai dit, c'est mon "ancien code" que je suis en train de modifier ;)
0
Utilisateur anonyme
22 août 2017 à 15:19
J'ai pas totalement fini, mais pour le moment, j'ai fais ça :
<?php
$mot = 'usb';
foreach(new RecursiveIteratorIterator(new RecursiveDirectoryIterator('groups/contenu/')) as $file){
	if(is_file($file)){
		$handle = fopen($file, 'r');
		if($handle) {
    		while(($buffer = fgets($handle, 4096)) !== false) {
        		if(preg_match("#$mot#", $buffer)){
        			echo $file.' : mot trouvé<br />';
        		}
    		}
    		fclose($handle);
		}
	}
}
?>
0