从字符串中打印固定数量的单词/ tkens

时间:2011-10-21 20:00:25

标签: php mysql

基本上我想知道如何从给定的字符串中打印固定数量的单词。或者,如果有办法让我的查询在$ data4引用的字段中存储有限数量的单词。在下面的例子中,我打印固定数量的字符$ data4变量,我宁愿没有任何单词被截断。

<?
$sysquery4 = mysql_query("SELECT * FROM content WHERE sid='59' AND title!='' ORDER BY id DESC LIMIT 4") or die(mysql_error());

while($data4 = mysql_fetch_array($sysquery4)) {
    $year = substr($data4['date'], 0, 4);
    $month = substr($data4['date'], 5, 2);
    $day = substr($data4['date'], 8, 2);
?>
<div class="post">

    <h2>
    <? echo $data4['title']; ?>
    </h2>
    <span class="news_date"><? echo date('F j, Y', mktime(0,0,0,$month,$day,$year)); ></span><br />
    <? echo substr($data4['content'], 0,180) ;echo $lnk="... more";  ?>

</div>
<? } ?>

1 个答案:

答案 0 :(得分:2)

您可以使用以下代码段(未经测试)解决此问题:

function limitWords($string, $num_words){
    //Pull an array of words out from the string (you can specify what delimeter you'd like)
    $array_of_words = explode(" ", $string);

    //Loop the array the requested number of times and build an output, re-inserting spaces.
    for ($i = 1; $i <= $num_words; $i++) {
        $output .= $array_of_words[$i] . " ";
    }
    return trim($output);
}

编辑:在最终输出周围添加一个修剪,以摆脱那个讨厌的最后一个附加空间。