调研工作越来越忽悠人了

前两天出差陪同某客户到我们下面厂进行调研,对于这个调研工作可能所有人之中就我最看重了,提前做好安排,包括时间确定、人员谈话、住宿等方面,可惜等到真正调研开始竟然如此简单,简单到想儿戏而言,感觉自己就是瞎操心,不过也让自己长了见识。

由于级别不到,该客户跟我们公司高管开会我没有资格参加,会后只是领导交代了我跟对方某领导对接工作,其中之一就是陪同他们前去调研。由于很多数据或东西未能直接公开或是给别人看到,所以这个度很不好把握,那时候还真的紧张了几天。等到约定前去调研的那天,反而平静很多,颇有一种“兵来将挡水来土掩”的感觉。

期待了大半个月的调研工作,换来的不过是几句话的事情,或者说是几分钟的事情,这个所谓的“调研”工作真的像是儿戏而已。可能我的眼界不够高,看不到别人看到的东西,只是这个调研工作给我的感觉就是完全没必要前去调研,这个工作完全就是一个电话或者一个邮件就可以搞定的事情,而不是像现在这样大张旗鼓地折腾了两天,而且几分钟就搞定,真的无法理解。对于这次调研,我都替对方某员工操心,因为当初完成之后他们领导要求他回去认真写调研报告,而据我所了解,这次调研根本就没有调研到什么东西,既然也要写报告?没有实际工作内容做支撑就写报告的事情是最累的,也是我最烦的,幸好这次只是对方烦而已,我这边不用写,只需要短信简单汇报给相关领导就过关了。

对于工作的每一件事我都是很认真地去完成,但是很多时候都感觉是自己过于重视,但是很多人都不当一回事。我的心态一直都是觉得“既然是工作就要努力去做好”,但是别人都是抱着玩玩的态度来对待,总有“道不同不相为谋”的感觉,可惜自己做不到那么硬气。

如何实现WordPress读者墙按评论等级显示相应读者?

我们国内很多WordPress主题都会带有一个读者墙功能,Nana主题也不一例外,但是看多了按总评论数的排行榜,是否有点腻歪?而且我们大多数主题都有评论等级的功能,是否想过读者按评论等级逐级显示出来?今天就教大家如何实现WordPress读者墙按评论等级显示相应读者。

以Nana主题为例,找到template-readers文件,复制一份并重名为template-pinglunbang,然后打开该文件,找到以下代码

Template Name: 读者百强榜

修改为

Template Name: 评论榜单

继续找到以下代码

<?php
function readers_wall($limit = "100")
{
	global $wpdb;
	$counts = $wpdb->get_results("SELECT count(comment_author) AS cnt, comment_author, comment_author_url, comment_author_email FROM $wpdb->comments WHERE user_id!='1' AND comment_author!='1' AND comment_approved='1' AND comment_type='' GROUP BY comment_author ORDER BY cnt DESC LIMIT $limit");
	$i = 0;
    $type='';
	foreach ($counts as $count ) {
		$i++;
		$c_url = $count->comment_author_url;

		if (!$c_url) {
			$c_url = "https://boke112.com";
		}

		$tt = $i;

		if ($i == 1) {
			$tt = "读者之青龙";
		}
		else if ($i == 2) {
			$tt = "读者之白虎";
		}
		else if ($i == 3) {
			$tt = "读者之朱雀";
		}
		else if ($i == 4) {
			$tt = "读者之玄武";
		}
		else {
			$tt = "第" . $i . "名";
		}
		$avatar = my_avatar( $count->comment_author_email,36,$default='',$count->comment_author);
		if ($i < 5) {
			$type .= "<a class=\"item-top item-" . $i . "\" target=\"_blank\" href=\"" . $c_url . "\" title=\"【" . $tt . "】评论:" . $count->cnt . "\"><h4>【" . $tt . "】</h4>".$avatar."<strong>" . $count->comment_author . "</strong>" . $c_url . "</a>";
		}
		else {
			$type .= "<a target=\"_blank\" href=\"" . $c_url . "\" title=\"【" . $tt . "】评论:" . $count->cnt . "\">" . $avatar . $count->comment_author . "</a>";
		}
	}

	echo $type;
}
?>
<div class="readers">
<?php readers_wall(100);?>
</div>

修改为

<?php
function readers_wall($limit = 100)
{
	global $wpdb;
    $counts = $wpdb->get_results("SELECT count(comment_author_email) AS cnt, comment_author, comment_author_url, comment_author_email FROM $wpdb->comments WHERE user_id!='1' AND comment_approved='1' AND comment_type='' AND comment_author_url!='' GROUP BY comment_author_email ORDER BY cnt DESC LIMIT 0 , $limit");
	$i1 = 0;$i2 = 0;$i3 = 0;$i4 = 0;$i5 = 0;$i6 = 0;$i7 = 0;$i8 = 0;
	$dj = 0;
	$xiucai = '';
	$juren = '';
	$jinshi = '';
	$zhuangyuan = '';
	$shangshu = '';
	$chengxiang = '';
	$wangye = '';
	$huangdi = '';
	foreach ($counts as $count ) {
		$dj=$count->cnt;
		$c_url = $count->comment_author_url;
		$avatar = my_avatar( $count->comment_author_email,36,$default='',$count->comment_author);
		if($dj >= 20 && $dj < 40){
		$i1++;			
		$xiucai .= "<a target=\"_blank\" href=\"" . $c_url . "\" title=\"评论量 " . $count->cnt . " 条,名列【秀才榜】第" . $i1 . "位\" target=\"_blank\" rel=\"external nofollow\">" . $avatar . $count->comment_author . "</a>";
		}
		if($dj >= 40 && $dj < 80){ 
		$i2++;
		$juren .= "<a target=\"_blank\" href=\"" . $c_url . "\" title=\"评论量 " . $count->cnt . " 条,名列【举人榜】第" . $i2 . "位\" target=\"_blank\" rel=\"external nofollow\">" . $avatar . $count->comment_author . "</a>";
		}
		if($dj >= 80 && $dj < 160){  
		$i3++;
		$jinshi .= "<a target=\"_blank\" href=\"" . $c_url . "\" title=\"评论量 " . $count->cnt . " 条,名列【进士榜】第" . $i3 . "位\" target=\"_blank\" rel=\"external nofollow\">" . $avatar . $count->comment_author . "</a>";
		}
		if($dj >= 160 && $dj < 320){  
		$i4++;
		$zhuangyuan .= "<a target=\"_blank\" href=\"" . $c_url . "\" title=\"评论量 " . $count->cnt . " 条,名列【状元榜】第" . $i4 . "位\" target=\"_blank\" rel=\"external nofollow\">" . $avatar . $count->comment_author . "</a>";
		}
		if($dj >= 320 && $dj < 640){ 
		$i5++; 
		$shangshu .= "<a target=\"_blank\" href=\"" . $c_url . "\" title=\"评论量 " . $count->cnt . " 条,名列【尚书榜】第" . $i5 . "位\" target=\"_blank\" rel=\"external nofollow\">" . $avatar . $count->comment_author . "</a>";
		}
		if($dj >= 640 && $dj < 1280){  
		$i6++;
		$chengxiang .= "<a target=\"_blank\" href=\"" . $c_url . "\" title=\"评论量 " . $count->cnt . " 条,名列【丞相榜】第" . $i6 . "位\" target=\"_blank\" rel=\"external nofollow\">" . $avatar . $count->comment_author . "</a>";
		}
		if($dj >= 1280 && $dj < 2560){  
		$i7++;
		$wangye .= "<a target=\"_blank\" href=\"" . $c_url . "\" title=\"评论量 " . $count->cnt . " 条,名列【王爷榜】第" . $i7 . "位\" target=\"_blank\" rel=\"external nofollow\">" . $avatar . $count->comment_author . "</a>";
		}
		if($dj >= 2560 && $dj < 100000){ 
		$i8++; 
		$huangdi .= "<a target=\"_blank\" href=\"" . $c_url . "\" title=\"评论量 " . $count->cnt . " 条,名列【皇帝榜】第" . $i8 . "位\" target=\"_blank\" rel=\"external nofollow\">" . $avatar . $count->comment_author . "</a>";
		}
	}
if(!empty($xiucai)){$xiucai ="<h2 style=\"border-left: 6px solid #FF0000;background-color: #FFD790;\"><strong>读者评论等级排行榜(秀才榜)</strong></h2><div class=\"readers\">".$xiucai."</div>";}
if(!empty($juren)){$juren ="<h2 style=\"border-left: 6px solid #FF0000;background-color: #FFD780;\"><strong>读者评论等级排行榜(举人榜)</strong></h2><div class=\"readers\">".$juren."</div>";}
if(!empty($jinshi)){$jinshi ="<h2 style=\"border-left: 6px solid #FF0000;background-color: #FFD770;\"><strong>读者评论等级排行榜(进士榜)</strong></h2><div class=\"readers\">".$jinshi."</div>";}
if(!empty($zhuangyuan)){$zhuangyuan ="<h2 style=\"border-left: 6px solid #FF0000;background-color: #FFD760;\"><strong>读者评论等级排行榜(状元榜)</strong></h2><div class=\"readers\">".$zhuangyuan."</div>";}
if(!empty($shangshu)){$shangshu ="<h2 style=\"border-left: 6px solid #FF0000;background-color: #FFD750;\"><strong>读者评论等级排行榜(尚书榜)</strong></h2><div class=\"readers\">".$shangshu."</div>";}
if(!empty($chengxiang)){$chengxiang ="<h2 style=\"border-left: 6px solid #FF0000;background-color: #FFD740;\"><strong>读者评论等级排行榜(丞相榜)</strong></h2><div class=\"readers\">".$chengxiang."</div>";}
if(!empty($wangye)){$wangye ="<h2 style=\"border-left: 6px solid #FF0000;background-color: #FFD720;\"><strong>读者评论等级排行榜(王爷榜)</strong></h2><div class=\"readers\">".$wangye."</div>";}
	if(!empty($huangdi)){$huangdi ="<h2 style=\"border-left: 6px solid #FF0000;background-color: #FFD700;\"><strong>读者评论等级排行榜(皇帝榜)</strong></h2><div class=\"readers\">".$huangdi."</div>";}	
	echo $huangdi;echo $wangye;echo $chengxiang;echo $shangshu;echo $zhuangyuan;echo $jinshi;echo $juren;echo $xiucai;
}
readers_wall(120);?>

保存上传到主题文件。

PS:其中评论的等级名称及相对应的评论数量请自行修改即可。

后台新建一个页面,模板就选我们刚才新创建的“评论榜单”然后直接修好好固定链接之后直接发布即可。

WordPress侧边栏如何添加站点统计信息?

我们建立站点有一段时间之后,就想在侧边栏显示我们站点的相关统计信息,比如站点已经运行多少天、发布了多少篇文章、有多少条评论,有多少阅读量等等。但是WordPress自身是不带有这个功能的,所以需要我们自己注册一个站点统计小工具,然后通过后台 >> 外观 >> 小工具 >> 找到站点统计小工具,然后添加到相应的侧边栏即可。

站点统计小工具实现办法

1、新建一个sidebar_tongji.php文件,并将以下代码添加到sidebar_tongji.php文件中。或者点此直接下载sidebar_tongji.php文件(密码:dyme)。

<?php

// 站点统计小工具
// 代码来自网络,版权无从考究


// 定义小工具的类 EfanBlogStat
class EfanBlogStat extends WP_Widget{

	function EfanBlogStat(){
		// 定义小工具的构造函数
		$widget_ops = array('classname' => 'widget_blogstat', 'description' => '显示站点的统计信息');
		$this->WP_Widget(false, '站点统计', $widget_ops);
	}
	
	function form($instance){
		// 表单函数,控制后台显示
		// $instance 为之前保存过的数据
		// 如果之前没有数据的话,设置默认量
		$instance = wp_parse_args(
			(array)$instance,
			array(
				'title' => '站点统计',
				'establish_time' => '2018-01-01'
			)
		);

		$title = htmlspecialchars($instance['title']);
		$establish_time = htmlspecialchars($instance['establish_time']);
		
		
		// 表格布局输出表单
		$output = '<table>';
		$output .= '<tr><td>标题</td><td>';
		$output .= '<input id="'.$this->get_field_id('title') .'" name="'.$this->get_field_name('title').'" type="text" value="'.$instance['title'].'" />';
		$output .= '</td></tr><tr><td>建站日期:</td><td>';   
		$output .= '<input id="'.$this->get_field_id('establish_time') .'" name="'.$this->get_field_name('establish_time').'" type="text" value="'.$instance['establish_time'].'" />';   
		$output .= '</td></tr></table>';  
		
		echo $output;   
	}
	
	function update($new_instance, $old_instance){
		// 更新数据的函数
		$instance = $old_instance;
		// 数据处理
		$instance['title'] = strip_tags(stripslashes($new_instance['title']));
		$instance['establish_time'] = strip_tags(stripslashes($new_instance['establish_time']));

		return $instance;
	}
	
	function widget($args, $instance){
		extract($args); //展开数组
		$title = apply_filters('widget_title',empty($instance['title']) ? '&nbsp;' : $instance['title']);
		$establish_time = empty($instance['establish_time']) ? '2018-01-01' : $instance['establish_time'];
		echo $before_widget;
		echo $before_title . $title . $after_title;
		echo '<ul>';
		// $this->efan_get_blogstat($establish_time, $instance);
		$this->efan_get_blogstat($establish_time);
		echo '</ul>';
		echo $after_widget;
	}
	
	function efan_get_blogstat($establish_time /*, $instance */){
		// 相关数据的获取
		global $wpdb;
		$count_posts = wp_count_posts();
		$published_posts = $count_posts->publish;
		$comments_count = $wpdb->get_var("SELECT COUNT(*) FROM $wpdb->comments");
		$time = floor((time()-strtotime($establish_time))/86400);
		$count_tags = wp_count_terms('post_tag');
		$count_pages = wp_count_posts('page');
		$page_posts = $count_pages->publish;
		$count_categories = wp_count_terms('category'); 
		$link = $wpdb->get_var("SELECT COUNT(*) FROM $wpdb->links WHERE link_visible = 'Y'"); 
		$last = $wpdb->get_results("SELECT MAX(post_modified) AS MAX_m FROM $wpdb->posts WHERE (post_type = 'post' OR post_type = 'page') AND (post_status = 'publish' OR post_status = 'private')");
		$last = date('Y-n-j', strtotime($last[0]->MAX_m));
		$total_views = $wpdb->get_var("SELECT SUM(meta_value+0) FROM $wpdb->postmeta WHERE meta_key = 'views'");  
		// 显示数据

		$output = '<li>日志总数:';
		$output .= $published_posts;
		$output .= ' 篇</li>';
		$output .= '<li>评论数目:';
		$output .= $comments_count;
		$output .= ' 条</li>';
		$output .= '<li>页面总数:';
		$output .= $page_posts;
		$output .= ' 个</li>';
		$output .= '<li>分类总数:';
		$output .= $count_categories;
		$output .= ' 个</li>';
		$output .= '<li>标签总数:';
		$output .= $count_tags;
		$output .= ' 个</li>';
		$output .= '<li>友链总数:';
		$output .= $link;
		$output .= ' 个</li>';
		$output .= '<li>浏览次数:';
		$output .= $total_views;
		$output .= ' 次</li>';
		$output .= '<li>建站日期:';
		$output .= $establish_time;
		$output .= '</li>';
		$output .= '<li>运行天数:';
		$output .= $time;
		$output .= ' 天</li>';
		$output .= '<li>最后更新:';
		$output .= $last;
		$output .= '</li>';
		
		echo $output;
	}
}

function EfanBlogStat(){
	// 注册小工具
	register_widget('EfanBlogStat');
}

add_action('widgets_init','EfanBlogStat');

?>

2、将步骤1的sidebar_tongji.php文件上传到当前主题文件夹内,并在当前主题的functions.php文件最后一个?>的前面添加一下代码

//添加站点统计小工具文件
include("sidebar_tongji.php");

请注意:如果sidebar_tongji.php文件不是放在根目录,那么第2步引用sidebar_tongji.php文件的路径就要做相应调整才行。比如是存放在主题文件的inc文件夹内,那么就应该是:

//添加站点统计小工具文件
include("sidebar_tongji.php");

具体效果如下:

如何输出自定义类型文章的所有分类和所有标签?

昨天我们介绍了WordPress站点如何添加自定义类型文章、分类和标签?,既然已经为我们的自定义类型文章添加了分类和标签,那么如果我们想在某个地方输出某个自定义类型文章的所有分类或者所有标签又应该怎么做呢?

其实这个问题还是挺简单的,我们以昨天那篇添加自定义类型文章的分类和标签为例进行说明。

1、显示自定义类型文章的所有分类:

只需要在需要显示某个自定义类型文章的所有分类处添加以下代码即可:

<?php
	$terms = get_terms("taobao");
	$count = count($terms);
	if ( $count > 0 ){
		foreach ( $terms as $term ) {
			echo '<a href="' . get_term_link( $term ) . '" target="_blank" rel="tag">' . $term->name . '</a>';
		}
	}
?>

2、显示自定义类型文章的所有标签:

只需要在需要显示某个自定义类型文章的所有标签处添加以下代码即可:

<?php
	$terms = get_terms("taotag");
	$count = count($terms);
	if ( $count > 0 ){
		foreach ( $terms as $term ) {
			echo '<a href="' . get_term_link( $term ) . '" target="_blank" rel="tag">' . $term->name . '</a>';
		}
	}
?>

温馨提示:大家记得修改以上代码的taobao或taotag为自己站点的自定义类型文章分类和标签相对应的slug,要不然会出错哦。至于输出的具体样式就需要大家自行调整添加了。

WordPress站点如何添加自定义类型文章、分类和标签?

网上大部分人分享添加WordPress自定义类型文章的代码,一般都是包含了文章和分类,最多就是添加一个跟文章类型post共用一个标签库,但是默认标签库的数量是增加了,但是点击查看该标签文章却没有那么多,只能看到post类型的文章,而看不到自定义文章类型,所以最好的方案就是为自定义类型的文章弄一个独立的标签库。

将以下代码添加到当前主题的functions.php文件中,或者添加到一个文章类型的post_type.php文件,然后在functions.php文件中引用该文章类型文件即可。

// 商品
add_action( 'init', 'post_type_tao' );
function post_type_tao() {
	$labels = array(
		'name'               => '商品', 'post type general name', 'your-plugin-textdomain',
		'singular_name'      => '商品', 'post type singular name', 'your-plugin-textdomain',
		'menu_name'          => '商品', 'admin menu', 'your-plugin-textdomain',
		'name_admin_bar'     => '商品', 'add new on admin bar', 'your-plugin-textdomain',
		'add_new'            => '发布商品', 'tao', 'your-plugin-textdomain',
		'add_new_item'       => '发布新商品', 'your-plugin-textdomain',
		'new_item'           => '新商品', 'your-plugin-textdomain',
		'edit_item'          => '编辑商品', 'your-plugin-textdomain',
		'view_item'          => '查看商品', 'your-plugin-textdomain',
		'all_items'          => '所有商品', 'your-plugin-textdomain',
		'search_items'       => '搜索商品', 'your-plugin-textdomain',
		'parent_item_colon'  => 'Parent 商品:', 'your-plugin-textdomain',
		'not_found'          => '你还没有发布商品。', 'your-plugin-textdomain',
		'not_found_in_trash' => '回收站中没有商品。', 'your-plugin-textdomain'
	);

	$args = array(
		'labels'             => $labels,
		'public'             => true,
		'publicly_queryable' => true,
		'show_ui'            => true,
		'show_in_menu'       => true,
		'query_var'          => true,
		'rewrite'            => array( 'slug' => tao ),
		'capability_type'    => 'post',
		'menu_icon'          => 'dashicons-cart',
		'has_archive'        => false,
		'hierarchical'       => false,
		'menu_position'      => 10,
		'supports'           => array( 'title', 'editor', 'author', 'excerpt', 'comments', 'thumbnail', 'revisions', 'custom-fields' )
	);

	register_post_type( 'tao', $args );
}


// 商品分类
add_action( 'init', 'create_tao_taxonomies', 0 );
function create_tao_taxonomies() {
	$labels = array(
		'name'              => '商品分类目录', 'taxonomy general name',
		'singular_name'     => '商品分类', 'taxonomy singular name',
		'search_items'      => '搜索商品目录',
		'all_items'         => '所有商品目录',
		'parent_item'       => 'Parent Genre',
		'parent_item_colon' => 'Parent Genre:',
		'edit_item'         => '编辑商品目录',
		'update_item'       => '更新商品目录',
		'add_new_item'      => '添加新商品目录',
		'new_item_name'     => 'New Genre Name',
		'menu_name'         => '商品分类',
	);

	$args = array(
		'hierarchical'      => true,
		'labels'            => $labels,
		'show_ui'           => true,
		'show_admin_column' => true,
		'query_var'         => true,
		'rewrite'           => array( 'slug' => taobao),
	);

	register_taxonomy( 'taobao', array( 'tao' ), $args );
}

// 商品标签
add_action( 'init', 'create_tao_tag_taxonomies', 0 );
function create_tao_tag_taxonomies() {
	$labels = array(
		'name'              => '商品标签', 'taxonomy general name',
		'singular_name'     => '商品标签', 'taxonomy singular name',
		'search_items'      => '搜索商品标签',
		'all_items'         => '所有商品标签',
		'parent_item'       => 'Parent Genre',
		'parent_item_colon' => 'Parent Genre:',
		'edit_item'         => '编辑商品标签',
		'update_item'       => '更新商品标签',
		'add_new_item'      => '添加新商品标签',
		'new_item_name'     => 'New Genre Name',
		'menu_name'         => '商品标签',
	);

	$args = array(
		'hierarchical'      => false,
		'labels'            => $labels,
		'show_ui'           => true,
		'show_admin_column' => true,
		'query_var'         => true,
		'rewrite'           => array( 'slug' => taotag ),
	);

	register_taxonomy( 'taotag', array( 'tao' ), $args );
}

 

以上代码为添加自定义类型的文章、分类和标签,具体请自行修改里面自定义类型的标题、slug等内容。想创建多个自定义类型文章、分类和标签,直接重复上述代码,并修改为其他的标题及slug即可。