2011-03
2

当Excel遇上WordPress

By xrspook @ 18:12:29 归类于: 烂日记

利用Excel,利用WordPress,应该能进化出我需要的东西。当规范化碰上规范化,理论上应该不会出什么乱子。为什么这么说呢?因为把Excel的东西粘贴到BlogBus的可视化编辑窗口,BlogBus把Microsoft的大部分东西都搬过去了,注意,是大部分!所以,有些格式存在,有些格式不存在,但WordPress的可视化窗口不一样,或许,粘到里面的和Excel里看到的有区别,因为那些很繁琐重复的句子,没有必要一定存在的句子它全部自动删除了,只剩下最核心的东西。这很好,而且,也就能解释为什么用Excel粘贴到Word再自动生成.htm文件大小为312KB,而用WordPress编辑后生成的,大小仅为49KB。这就是标准化的威力,标准是为了化繁为简,我也相信从WordPress里自动生成的源代码贴到哪里都一样,我不是个表格控,表格一直是我最头疼的东西,非万不得已,我不会在网页上使用表格。因为表格是个不利于网页源代码编写的东西,太累赘,太无法标记了。

之前从来没想过居然可以用WordPress生成一个网页,只要把WP header.php和footer.php的东西选择性合并到一个新模板里,一切皆有可能,当然啦,前提是你是故意要把那个模板弄成和其它页面完全不一样的,否则,利用通用的header.php和footer.php就好。

很高兴,做了一件很有意义的事。谢谢WordPress,这东西怎么老是可以给我成功感呢,嘻嘻嘻。

明天,要去疯狂了!

深圳欢乐谷,面对变态的机动游戏,我会很淡定的,尖叫,no way。

2010-12
9

持续改进

By xrspook @ 21:24:59 归类于: 烂日记

wp3.0.2升级感觉才一周,wp3.0.3又来了,又是安全问题,不过这个3.0.3只涉及远程发布的安全问题,所以只需更新很少一部分文件(就4个文件)就可以了。

重新启用了tweet.im,感觉我实在miss客户端,我太miss那些能随便t的日子,太miss那些从t上接收的信息。推而广之,我越发miss那些和妈到处吃的日子,更加miss那些可以随便晚睡不用担心身体出状况的青春。死不可怕,半死不活才最折磨人。每时每刻都在想怎么和别人斗牛的日子不好过。

今天早上很成功,7点半扦样的准时出发,7点45告诉我第一个样品到了,8点整,其余3个都送了过来,于是,非常神速地8点20之前搞定了所有,包括收拾东西和搞卫生。今天最后一个样品还卡砻谷机呢,不过幸好卡机之前已经积攒到足够多的糙米进行下一步操作,所以,卡机就卡机呗,大不了拧开几个螺丝找个吸尘器给它两下。感觉那个砻谷机比我手掌心愈合不久的新皮还敏感,每天总得卡那么一次或以上。国人设计的机器就不能“聪明”一点?非常想知道日本的实验砻谷机是怎样的,非常肯定的是质量一定比我们好,不会经常卡机,即便会卡机,打开机盖也会比我们的人性化。昨天下午换了个砻谷机的皮带,足足得拧开不下10个螺丝,而且还必须用到扳手。几周前,手指就是开砻谷机盖的时候被划到的,现在我再也不会赤手空拳去对付那麻烦的东西,必须找个螺丝刀去撬!

砻谷机经常卡机,碾米机出来的米断腰特多,整精米率不堪设想。这些国产货已经到达了一种让人非常厌恶的地步了。真不知道那些老是稻谷检验的人是怎么活过来的。除了认命就什么都不能干了?

很多很多东西都需要改进,就看你有没有持续上进的心的。

2010-08
26

当年今日入rss啦

By xrspook @ 23:02:56 归类于: 烂日记

众里寻他千百度,蓦然回首,那人却在灯火阑珊处。

上星期已经把“当年今日”功能加到blog里(详细见Arm 2 W),从一开始就打算要加入rss的,但费尽九牛二虎之力都没做到,但今天,终于攻克了!

到底什么原因呢?

首先,我们要看我当年今日的源代码,利用

< ?php wp_today();? >

完成插入,在function.php的代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
function wp_today(){
	$title = "<h3>当年今日</h3>";
	$limit = 10;
	$order = "latest";
	$post = 1;
	$feed = 1;
 
 
	global $wpdb;
	$post_year = get_the_time('Y');
	$post_month = get_the_time('m');
	$post_day = get_the_time('j');
	if($order == "latest"){ $order = "DESC";} else { $order = '';}
 
	$sql = "select ID, date(post_date_gmt) as h_date, post_title, comment_count FROM 
			$wpdb->posts WHERE post_password = '' AND post_type = 'post' AND post_status = 'publish'
			AND year(post_date_gmt)!='$post_year' AND month(post_date_gmt)='$post_month' AND day(post_date_gmt)='$post_day'
			order by post_date_gmt $order limit $limit";
	$histtory_post = $wpdb->get_results($sql);
	if( $histtory_post ){
		foreach( $histtory_post as $post ){
			$h_date = $post->h_date;
			$h_post_title = $post->post_title;
			$h_permalink = get_permalink( $post->ID );
			$h_comments = $post->comment_count;
			$h_post .= "<li>$h_date -- <a href='".$h_permalink."' title='Permanent Link to ".$h_post_title."'>$h_post_title</a> <!--($h_comments) --></li>";
		}
	}
 
	if ( $h_post ){
		$result = "".$title."<ul>".$h_post."</ul>";
	}
	echo $result;	
}

这堆代码,要实现在blog的某个位置输出当年今日没有任何问题,但要注意,数据是用“echo $result;”完结的,这就埋下了伏笔。

我试过很多回,试图在function.php加入以下这堆代码调用上面的代码实现当年今日在rss中的输出:

1
2
3
4
5
6
7
8
9
10
function wp_today_rss($content){
    if (is_feed()){
		$content = $content.wp_today();
		return $content;
	}
	else {
		return $content;
	}
}
add_filter('the_content', 'wp_today_rss');

输出是能输出了,但结果很囧,见图:

当年今日输出在了正文前面!(那堆乱码东西是正文),但代码中我明明是这般写的“$content = $content.wp_today();”,东西应该加在后面的,但实际上却在前面,这让我百思不得其解。

无可奈何,今天试过用最笨的方法把wp_today()除echo $result;以外的数据全部往function wp_today_rss里放,能实现了我希望的效果,见图:

到底怎么办呢?难道要很笨地把同1段代码写2回?????

狂抓不已,于是就去请教别人了,但一请教,人家还没回答我就有了头绪,不如把上面两段代码拆分为3段,即:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
function get_today(){
	$title = "<h3>当年今日</h3>";
	$limit = 10;
	$order = "latest";
	$post = 1;
	$feed = 1;
 
 
	global $wpdb;
	$post_year = get_the_time('Y');
	$post_month = get_the_time('m');
	$post_day = get_the_time('j');
	if($order == "latest"){ $order = "DESC";} else { $order = '';}
 
	$sql = "select ID, date(post_date_gmt) as h_date, post_title, comment_count FROM 
			$wpdb->posts WHERE post_password = '' AND post_type = 'post' AND post_status = 'publish'
			AND year(post_date_gmt)!='$post_year' AND month(post_date_gmt)='$post_month' AND day(post_date_gmt)='$post_day'
			order by post_date_gmt $order limit $limit";
	$histtory_post = $wpdb->get_results($sql);
	if( $histtory_post ){
		foreach( $histtory_post as $post ){
			$h_date = $post->h_date;
			$h_post_title = $post->post_title;
			$h_permalink = get_permalink( $post->ID );
			$h_comments = $post->comment_count;
			$h_post .= "<li>$h_date -- <a href='".$h_permalink."' title='Permanent Link to ".$h_post_title."'>$h_post_title</a> <!--($h_comments) --></li>";
		}
	}
 
	if ( $h_post ){
		$result = "".$title."<ul>".$h_post."</ul>";
	}
	return $result;
}
function wp_today(){
	echo get_today();
}
function wp_today_rss($content){
    if (is_feed()){
		$content = $content.get_today();
		return $content;
	}
	else {
		return $content;
	}
}
add_filter('the_content', 'wp_today_rss');

嘿嘿,对味!function get_today()是核心代码,function wp_today()用作来打印输出,function wp_today_rss()使之能加入到rss中。哈,“echo $result;”换成了“return $result;”解决了纠结我很久的千古难题。只能叹一句,从前的函数调用没领会透,也没有认真留意数据返回那些事。

最后,终于把问题解决了,爽得飞天,哈哈哈~~~~

PS:感谢SH童鞋的鼎力支持!

PS2:代码可能在rss中不能全部显示,有需要者请移步网页。

2010-08
19

Arm 2 W

By xrspook @ 22:22:57 归类于: 烂日记

还记得那个短语armed to the teeth?!武装到牙齿啊!(having many weapons 全副武装)这个“Arm 2 W”又是什么意思呢?Arm,作动词,继续表示装备;2,有二的意思,也有to的意思;W,亲爱的WordPress。今天为WordPress装备了2个新武器,大大增加阅读的延展性。

1、WordPress Related Posts:鼎鼎大名的相关文章插件,利用的是tags的相关性。这个插件我是直接装了,貌似很复杂,而且是水煮鱼的产品,一切都非常人性化,可以作widget也可以代码插入,想插哪里就插哪里,而且作者已经预留了一些可自定义的class,所以要格式化很简便。

2、WP-Today:历史上的今天,对于我的blog来说,历史悠久且记录齐全,历史上的今天很有必要摆出来show一show,嘿嘿。这个插件原理比较简单,而且由于作者并没有把插件小工具话,只能自动连到文章末端,也有手动设置,但我试了好多次都不成功,于是把代码经过修改后直接贴到自己Color3的function.php里了。

有图有真相。

第一个插件没费我多少心思就完成安装格式化了,但第二个,折腾了我好久。虽然玩wp的时间不短了,但对function.php还是不熟悉,那片土地对我来说简直就是亚马逊的原始森林。即便加个简单的function {}也会让我狠抓,因为修改这里和修改wp主题的其他文件不一样,一旦有任何差错无论前台后台都会一片空白,幸好我是脱机调试,在Notepad++上修改,所以还能经常重来。WP-Today这个插件原始版本是这样的,但如果插入主题的function.php就不需要全部,只需要部分,我只加了这些

我把它的默认条数限制从5条调整为10条,把只显示年份改为显示标准的Y-m-d(年年年年-月月-日日)。

关于function.php的代码插入法,很有必要简单总结一下:

一、若插入的function {}中间并无使用,可以直接把代码插到括号中;
二、若function {}中有使用,需要…,“…”代表那些含html和php格式的部分,不明白为什么要这么弄,但貌似都是这般折腾的。

我的天最重要的价值在于TA的坚持,希望这样的改进能让读者多转几分钟吧,嘻嘻。

2010-08
18

极速升级wp3.0.1

By xrspook @ 17:49:06 归类于: 烂日记

蠢蠢欲动之后,昨晚终于逮到机会,把wp给升了。

以前升级都是用FTP,首先把旧版本wp内除wp-content文件夹外的东西全部删除,然后把新版本的同样部分放上去,接着再把新翻译文件替换掉wp-content\languages的东西。这般折腾不是一般的费时。因为服务器上的文件都是非压缩状态的,同样大的文件,.zip压缩可以缩小70-80%,水分很大啊!当网速很一般的时候更是恐怖,一般的ADSL无论下载速度有多少M,上传通常只有50KB,而这里用的是光纤,上传才侥幸能达到2MB,但尽管如此,上传十几MB的零散东西还是很费时。于是,传统FTP方法下来,顺利的话也得折腾1.5-2小时。

但这次,我利用的是web传送,登录lighttpd的后台,选择FileManger,把要上传的东西打包.zip传到上面去。请注意,不要把从官网弄下来的.zip就直接传上去哦,如此一来,你在模板和插件上的修改就全部泡汤了!而那些东西都在wp-content文件夹内,所以,其它文件打包,这个除外。lighttpd的上传方式有3种,分别是本地上传,网址转传,还有就是FTP,因为需要修改,所以我用的是本地上传,再次强调,别以为很聪明就用官网的下载地址贴到网络转传那里!嘿嘿,以wordpress3.0.1大小约3MB的.zip文件为例,我上传只用了1秒不到,秒杀完成。

接着,在目录就能看你上传的.zip文件。为什么是.zip呢?因为Linux系统是不认.rar的。

点进.zip文件,系统能把.zip文件看透,我们来个解压(Extract Zip To Here)就万事大吉了。服务器那边的解压比我的电脑还要快,眨眼间就OK了。

接下来的事就是把旧版本的wp文件删掉,把新版本的剪切过去。

最后最后,如果你用的不是非官方英文版的话,记得把你的翻译文件放回wp-content\languages,就只有2个文件,用FTP也很好。

至此,wordpress的升级就大功告成。如果你手脚麻利,网络又通畅的话,绝对可以在5分钟内完成,大大的节省时间啊!最后,还是要不厌其烦地提醒一句,无论什么形式的升级,升级前最好先备份数据库,把所有插件停用掉,始终,避免数据丢失和各种冲突还是很有必要的。

上面的方法适用于lighttpd后台,因为lighttpd后台没有上传.zip文件的功能,但VistaPanel(很多免费空间都用这个)就更简单,因为那是允许上传zip,tar,tgz,gz并自解压的,所以能省掉上传、解压的过程。在免费空间对比利用上传压缩文件和传统FTP上传其优越性会更明显。

wp升级其实很轻松,哈哈哈~~~

终于升到了目标的3.0.1,看到那个界面却让我呆了。不知是不是用惯了2.*,到了3.*,那些纯粹的灰色让我觉得刺眼,同时,各种更新提示也从以前的橘红色变成了黑色了,囧,这个我不喜欢呢。有图有真相:

wordpress 3.0.1控制台

wordpress 2.9.2控制台

很好奇地翻了翻导航栏,只在外观里发现了个新条目——目录,一个排序的东东,对我没什么吸引力。哎~~~ 苦得我那么心急要升级,没什么让我眼前一亮的东西,有点扫兴。

但,总算跟上时代步伐了:)))

© 2004 - 2024 我的天 | Theme by xrspook | Power by WordPress