Как я могу усечь строку после 20 слов в PHP?
function limit_text($text, $limit) { if (str_word_count($text, 0) > $limit) { $words = str_word_count($text, 2); $pos = array_keys($words); $text = substr($text, 0, $pos[$limit]) . '...'; } return $text; } echo limit_text('Hello here is a long sentence blah blah blah blah blah hahahaha haha haaaaaa', 5);
Выходы:
Hello here is a long ...
измените число 2
на число 19
ниже, чтобы получить первые 20 слов. Следующее демонстрирует использование 2
чтобы получить первые 3 слова: (так измените 2
на 19
и он даст вам первые 20 слов)
function first3words($s) { return preg_replace('/((\w+\W*){2}(\w+))(.*)/', '${1}', $s); } var_dump(first3words("hello yes, world wah ha ha")); # => "hello yes, world" var_dump(first3words("hello yes,world wah ha ha")); # => "hello yes,world" var_dump(first3words("hello yes world wah ha ha")); # => "hello yes world" var_dump(first3words("hello yes world")); # => "hello yes world" var_dump(first3words("hello yes world.")); # => "hello yes world" var_dump(first3words("hello yes")); # => "hello yes" var_dump(first3words("hello")); # => "hello" var_dump(first3words("a")); # => "a" var_dump(first3words("")); # => ""
Усекает до ближайшего предшествующего пространства целевого символа. демонстрация
$str
Строка, подлежащая усечению $chars
Количество символов, которые нужно удалить, может быть переопределено $to_space
$to_space
boolean
для того, чтобы усечь из пространства около $chars
limit функция
function truncateString($str, $chars, $to_space, $replacement="...") { if($chars > strlen($str)) return $str; $str = substr($str, 0, $chars); $space_pos = strrpos($str, " "); if($to_space && $space_pos >= 0) $str = substr($str, 0, strrpos($str, " ")); return($str . $replacement); }
Образец
<?php $str = "this is a string that is just some text for you to test with"; print(truncateString($str, 20, false) . "\n"); print(truncateString($str, 22, false) . "\n"); print(truncateString($str, 24, true) . "\n"); print(truncateString($str, 26, true, " :)") . "\n"); print(truncateString($str, 28, true, "--") . "\n"); ?>
this is a string tha... this is a string that ... this is a string that... this is a string that is :) this is a string that is--
Простой и полностью экипированный метод truncate ():
function truncate($string, $width, $etc = ' ..') { $wrapped = explode('$trun$', wordwrap($string, $width, '$trun$', false), 2); return $wrapped[0] . (isset($wrapped[1]) ? $etc : ''); }
используйте explode () .
Пример из документов.
// Example 1 $pizza = "piece1 piece2 piece3 piece4 piece5 piece6"; $pieces = explode(" ", $pizza); echo $pieces[0]; // piece1 echo $pieces[1]; // piece2
обратите внимание, что функция breakode имеет предельную функцию. Таким образом, вы можете сделать что-то вроде
$message = implode(" ", explode(" ", $long_message, 20));
Это не мое собственное творение, его модификация предыдущих сообщений. кредиты идут на karim79.
function limit_text($text, $limit) { $strings = $text; if (strlen($text) > $limit) { $words = str_word_count($text, 2); $pos = array_keys($words); if(sizeof($pos) >$limit) { $text = substr($text, 0, $pos[$limit]) . '...'; } return $text; } return $text; }
Разделите строку (в массив) на <
space >
, а затем возьмите первые 20 элементов этого массива.
Это выглядит довольно хорошо для меня :
Общей проблемой при создании динамических веб-страниц (где контент поступает из базы данных, системы управления контентом или внешнего источника, такого как RSS-канал), является то, что входной текст может быть слишком длинным и заставлять макет страницы «ломаться».
Одним из решений является усечение текста, чтобы он соответствовал странице. Это звучит просто, но часто результаты не ожидаются из-за того, что слова и предложения прерываются в неподходящих точках.
Попробуйте регулярное выражение.
Вам нужно что-то, что соответствует 20 словам (или 20 границам слов).
Так что (мое регулярное выражение ужасно, так меня правильно, если это не точно):
/(\w+\b){20}/
И вот несколько примеров регулярного выражения в php .
С тройными точками:
function limitWords($text, $limit) { $word_arr = explode(" ", $text); if (count($word_arr) > $limit) { $words = implode(" ", array_slice($word_arr , 0, $limit) ) . ' ...'; return $words; } return $text; }
Что-то вроде этого, вероятно, может сделать трюк:
<?php $words = implode(' ', array_slice(split($input, ' ', 21), 0, 20));
используйте функцию PHP tokenizer strtok () в цикле.
$token = strtok($string, " "); // we assume that words are separated by sapce or tab $i = 0; $first20Words = ''; while ($token !== false && $i < 20) { $first20Words .= $token; $token = strtok(" "); $i++; } echo $first20Words;
на основе ответа 動靜 answer:
function truncate_words($string,$words=20) { return preg_replace('/((\w+\W*){'.($words-1).'}(\w+))(.*)/', '${1}', $string); }
или
function truncate_words_with_ellipsis($string,$words=20,$ellipsis=' ...') { $new = preg_replace('/((\w+\W*){'.($words-1).'}(\w+))(.*)/', '${1}', $string); if($new != $string){ return $new.$ellipsis; }else{ return $string; } }
Вот что я реализовал.
function summaryMode($text, $limit, $link) { if (str_word_count($text, 0) > $limit) { $numwords = str_word_count($text, 2); $pos = array_keys($numwords); $text = substr($text, 0, $pos[$limit]).'... <a href="'.$link.'">Read More</a>'; } return $text; }
Как вы можете видеть, это основано на ответе karim79, все, что нужно было изменить, было то, что оператор if также должен был проверять слова, а не символы.
Я также добавил ссылку на основную функцию для удобства. До сих пор он работал безупречно. Благодаря первому поставщику решений.
Вот один из них:
$truncate = function( $str, $length ) { if( strlen( $str ) > $length && false !== strpos( $str, ' ' ) ) { $str = preg_split( '/ [^ ]*$/', substr( $str, 0, $length )); return htmlspecialchars($str[0]) . '…'; } else { return htmlspecialchars($str); } }; return $truncate( $myStr, 50 );
$aContent = explode(' ', $cContent); $cContent = ''; $nCount = count($aContent); for($nI = 0; ($nI < 20 && $nI < $nCount); $nI++) { $cContent .= $aContent[$nI] . ' '; } trim($cContent, ' '); echo '<p>' . $cContent . '</p>';
Это также послужило для предложений UNICODE (UTF8) :
function myUTF8truncate($string, $width){ if (mb_str_word_count($string) > $width) { $string= preg_replace('/((\w+\W*|| [\p{L}]+\W*){'.($width-1).'}(\w+))(.*)/', '${1}', $string); } return $string; }
function getShortString($string,$wordCount,$etc = true) { $expString = explode(' ',$string); $wordsInString = count($expString); if($wordsInString >= $wordCount ) { $shortText = ''; for($i=0; $i < $wordCount-1; $i++) { $shortText .= $expString[$i].' '; } return $etc ? $shortText.='...' : $shortText; } else return $string; }
Попробуйте под кодом,
$text = implode(' ', array_slice(explode(' ', $text), 0, 32)) echo $text;
Чтобы ограничить слова, я использую следующий небольшой код:
$string = "hello world ! I love chocolate."; $explode = array_slice(explode(' ', $string), 0, 4); $implode = implode(" ",$explode); echo $implode;
$ implot даст: привет мир! я
как насчет
chunk_split($str,20);
Вступление в Руководство по PHP