preg_replace внезапно перестает делать различия

Посрамлены. Я использовал приведенный ниже IF PREG_MATCH, чтобы различать слова, которые являются целыми словами и словами, которые являются частями других слов. Он внезапно перестал функционировать в этом сценарии и любом другом используемом мной сценарии, которые зависят от этой команды.

В результате он находит части слов, хотя вы можете видеть, что ему явно сказано найти только слова целиком.

$word = preg_replace("/[^a-zA-Z 0-9]+/", " ", $word);                                        

if (preg_match('#\b'.$word.'\b#',$goodfile) && (trim($word) != ""))  { 

        $fate = strpos($goodfile,$word);
        print $word ."  ";
        print $fate ."</br>";

2 ответа

Это будет быстрее и чище, чем взорваться, и вы не будете делать массив

$first_word = stristr($lines, ' ', true); 

Если вы хотите прочитать только первое слово в строке текстового файла, как подсказывает ваш заголовок, попробуйте другой метод:

// Get the file as an array, each element being a line
$lines = file("/path/to/file"); 

// Break up the first line by spaces
$words = explode(" ", $lines[0]); 

// Get the first word
$firstWord = $words[0]; 
Другие вопросы по тегам