如何在php下输出数据库中的部分文本

在php平台下,在mysql数据库下有个存储用户的文章,也就是博客、日志之类的表,文章字段为content,现在我想实现只输出文章的前100个文字,文章后面的不输出,该如... 在php平台下,在mysql数据库下有个存储用户的文章,也就是博客、日志之类的表,文章字段为content,现在我想实现只输出文章的前100个文字,文章后面的不输出,该如何实现? 展开
 我来答
汲职0GL3f6
2012-02-29 · TA获得超过987个赞
知道小有建树答主
回答量:367
采纳率:0%
帮助的人:422万
展开全部
方法挺多的,我说2种:
第一种:程序:使用函数:
mb_substr( );  取得指定字符串一部分。
举例:
<?php
//假设你已经获取了文章,保存在$row['wz']中;
echo mb_substr($row['wz'],0,100,"GBK");//使用gbk码
?>
但是这么做只是取了前100个字符,所以我推荐第二种方法

第二种方法,使用mysql的函数::SUBSTRING()
假设你的数据表叫abc,文章放在bb里,你需要从开始第一个字到第100个字(符号也算一个)
那么SQL语句:SELECT SUBSTRING(bb,1,100) FROM abc;
然后程序直接输出就可以了

例如:
<?php
$res=mysql_query("SELECT SUBSTRING(bb,1,100) FROM abc");
$row=mysql_fetch_row($res);
echo $row[0];
?>

还有第三种,就是楼上的循环,自己抉择吧。我佩服1楼有那个耐心,自己写,实在不行才要自己写的。而且你这是切中文,一旦切错了,就是乱码,并且你的中文肯定有符号把,并且也不可能取出100个中文字,最多100个字符或者是几十个汉字加几个字符之类的。

----------------有疑问Hi我
xiezhilong167
2012-02-23 · TA获得超过109个赞
知道小有建树答主
回答量:148
采纳率:100%
帮助的人:132万
展开全部
首先在数据库读取文章出来,然后调用下面的数组切100个文字就行了
# ********************************************
# 切中文字符
# ********************************************
function cutstr($string, $length, $dot = '', $charset = '') {
if (strlen($string) <= $length) {
return $string;
}
$string = htmlspecialchars_decode($string);
$tmp_string = $string;
$string = strip_tags($string);

$strcut = '';
if (strtolower($charset) == 'utf-8') {
$n = $tn = $noc = 0;
while ($n < strlen($string)) {
$t = ord($string[$n]);
if($t == 9 || $t == 10 || (32 <= $t && $t <= 126)) {
$tn = 1; $n++; $noc++;
} elseif (194 <= $t && $t <= 223) {
$tn = 2; $n += 2; $noc += 2;
} elseif (224 <= $t && $t < 239) {
$tn = 3; $n += 3; $noc += 2;
} elseif (240 <= $t && $t <= 247) {
$tn = 4; $n += 4; $noc += 2;
} elseif (248 <= $t && $t <= 251) {
$tn = 5; $n += 5; $noc += 2;
} elseif ($t == 252 || $t == 253) {
$tn = 6; $n += 6; $noc += 2;
} else {
$n++;
}
if($noc >= $length) {
break;
}
}
if ($noc > $length) {
$n -= $tn;
}
$strcut = substr($string, 0, $n);
} else {
for ($i = 0; $i < $length; $i++) {
$strcut .= ord($string[$i]) > 127 ? $string[$i].$string[++$i] : $string[$i];
}
}
$strcut .= $dot ;
if($string != $tmp_string){
$tags_rep = '/(\<[^\>]+\>)/';
preg_match_all($tags_rep,$tmp_string,$tags);
if(!empty($tags[0])){
$offset = 0;
foreach($tags[0] as $val){
$pos = strpos($tmp_string,$val,$offset);
$strcut = str_insert($strcut,$pos,$val);
$offset = $pos;
}
}
}
return $strcut;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
gbsck
2012-03-08 · 超过13用户采纳过TA的回答
知道答主
回答量:49
采纳率:0%
帮助的人:37.4万
展开全部
内容里一般有html代码,首先要过滤掉html代码,然后在去前100个字
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
下砂zW
2012-02-28 · 超过20用户采纳过TA的回答
知道答主
回答量:65
采纳率:0%
帮助的人:44.2万
展开全部
很给力 学习了!
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式