在thinkphp中,写的博文标签多对多关系的标签频率统计算法

常常看到别人的博客里面,或者网站里面有这样随机颜色,但字体大小与标签出现频率有关的标签云,于是自己就想写一个。至于颜色的随机显示,那就很简单了,这里就不列代码。

在thinkphp中,写的博文标签多对多关系的标签频率统计算法

在thinkphp中,写的博文标签多对多关系的标签频率统计算法

因为正在学thinkphp,所以数据查找的都是用的tp数据查找语句。

在thinkphp中,写的博文标签多对多关系的标签频率统计算法
         Public function render( $data ){
//在博文——标签多对多关系的中间表中查找出所有的标签
$tags = M('blog_tags')->select();
$a = array();
//去掉重复的标签,将所有不重复的标签保存在数组a中
for($i=0; $i<count($tags); $i++) {
if( !in_array( $tags[$i]['tid'], $a ) ){
$a[$i] = $tags[$i]['tid'];
}
}
// 查找出这些标签下所有的博文id,保存在数组bid中
foreach ($a as $v) {
$bid[$v] = M('blog_tags')->where(array('tid'=>$v))->field('bid')->select();
}
foreach ($bid as $v) {
$blog_id[] = $v;
}
// p($a);
// p($blog_id);die;
$b = $a;//数组b用来保存原先的数组a,数组a统计标签出现的次数
foreach ($a as $k => $v) {
$a[$k] = array();
for( $j=0;$j<count($tags);$j++ ){
if( $v == $tags[$j]['tid'] )
$a[$k][0] += 1;
}
}
$i = 0;
//将标签id,统计的次数,标签名,博文的id,组合成一个数组c
foreach( $b as $k=>$v ){
$name = M('tags')->where(array('id' => $v))->getField('name');
$c[$i] = array( 'id' => $v, 'num' => $a[$k][0], 'name' => $name,'bid'=>$blog_id[$i] );
$i++;
}
// p($c);die; $data['tags'] = $c;
return $this->renderFile('', $data);
}
上一篇:闭包的理解-from my own opinion


下一篇:LCD显示方向