截取文章标题 $content =str_replace("<IMG "," ",$content);先把取出来的东西过滤一下 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 function sub_str($string, $length = 0, $append = true){ if(strlen($string) <= $length) { return $string; } $string = str_replace(array('&', '"', '<', '>'), array('&', '"', '<', '>'), $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 = str_replace(array('&', '"', '<', '>'), array('&', '"', '<', '>'), $strcut); if ($append && $string != $strcut) { $strcut .= '...'; } return $strcut; }中文截取 用strip_tags()去掉html标签用mb_substr截取中文,具体翻翻手册另外 标题最好用css对表格控制,隐藏多余的,这样搜索引擎还能找到完整的 有时候用css隐藏标题看起来不太美观,就加一个title="$title",方便搜索引擎吧~ 网找了半天基本都是遍历每一个字再取ord()进行比较再加'...',一个页面上百条数据外理起来有点太劳师动众了。于是就自己查资料写了一个中英文截取函数,全是用正则和系统函数来完成的,也不知道效率上会不会好一点。是utf8的。考虑到单字节(半角)与双字节(全角)在显示上宽度不同,所以是以汉字为基准截取。具体原理是遇到单字节便两个放到一个数组,双字节的一个为一个数组,然后将数组join成一个字符串。function utf8Sub($str,$len){//len是双字节数两个字母为1 preg_match_all("/[^\x80-\xff]{2}|[^\x80-\xff]|[\x80-\xff]{3}/",$str,$arr); if(count($arr[0])>$len){ return join('',array_splice($arr[0],0,$len)).'...'; }else{ return join('',$arr[0]); }}$aaa='artwc.com小米布枪同志';echo utf8Sub($aaa,9); PHP做会员登陆系统,要输入两次才能登陆成功,什么问题? php文件权限 请教window.open向php页面传值的问题 调用一个.net soap PHP获取数据库表中字段的值 PHP论坛发贴文本域上方工具按钮问题 注册多个session。初使化后有有此SESSION的数据不见了。 这是怎么回事呀。 急!!~~~ 初学PHP,觉得国内讨论PHP的站点很少,也没什么教程 有可以把PDF文件转化为DOC文件的程序吗? php爬虫求伸手QAQ 有关SupeSite6.0调用数据库问题 我用cURL抓取了一个页面,只想要里面某个标签中的内容,怎么办?
if(strlen($string) <= $length) {
return $string;
}
$string = str_replace(array('&', '"', '<', '>'), array('&', '"', '<', '>'), $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 = str_replace(array('&', '"', '<', '>'), array('&', '"', '<', '>'), $strcut);
if ($append && $string != $strcut)
{
$strcut .= '...';
}
return $strcut;
}中文截取
用mb_substr截取中文,具体翻翻手册
另外 标题最好用css对表格控制,隐藏多余的,这样搜索引擎还能找到完整的
有时候用css隐藏标题看起来不太美观,就加一个title="$title",方便搜索引擎吧~
于是就自己查资料写了一个中英文截取函数,全是用正则和系统函数来完成的,也不知道效率上会不会好一点。是utf8的。
考虑到单字节(半角)与双字节(全角)在显示上宽度不同,所以是以汉字为基准截取。
具体原理是遇到单字节便两个放到一个数组,双字节的一个为一个数组,然后将数组join成一个字符串。function utf8Sub($str,$len){//len是双字节数两个字母为1
preg_match_all("/[^\x80-\xff]{2}|[^\x80-\xff]|[\x80-\xff]{3}/",$str,$arr);
if(count($arr[0])>$len){
return join('',array_splice($arr[0],0,$len)).'...';
}else{
return join('',$arr[0]);
}
}
$aaa='artwc.com小米布枪同志';
echo utf8Sub($aaa,9);