I am LAZY bones ? all linux

2009年 01月 的归档

假期看完了《三体》

《三体》是个不错的科幻小说,记得是在irc里听不知道是谁说起过,就下载了,一直放着也没仔细看。后来下了个黑莓的读书软件,据说可以转换pdf的文档,就实验性地把这书转换了,放进了黑莓,没想到这正好可以填充我寒假(虽然只有几天的假期,但也先保留这个称号吧)的零碎空余时间。
这大概是我第一次正儿八经地看完一个长篇小说,其实刚开始我也没觉得自己会看完,但后来确实被故事吸引了,呵呵。
正儿八经的书评咱也写不来,自己觉得好看,也推荐给喜欢科幻的朋友吧。另外,建议看小说之前先把Dimensions看一遍,对数学的发展史及高维空间有个初步的认识,会更加有趣的。

Foxit Reader for linux

之前都是用evince来看PDF文档的,其实也挺好的,就是evince没有习惯的手形工具,而且选择文本的时候,还会有残字现象,所以对它多少有点不满.
刚好看到linuxtoy上有介绍Foxit Reader for linux的文章,就下载了试验了一下,这个工具在windows下就是我的必备常用工具之一(我可受不了adobe reader那体积),所以对它的期待还是蛮高的.不过试用过后,觉得也就一般而已.主要是有下面几点问题:

  • 对中文支持不好,不是打不开中文PDF,而是菜单什么的没有中文
  • 工具栏还有bug,正常状态有手形/文字选择/截图等工具按钮,全屏以后成了另一套,再取消全屏以后,工具栏却没换回来,还是有那个”取消全屏”按钮,不过这个毕竟是beta版本的,正式版应该会得到修改.
  • 不是开源软件,而且觉得对免费用户有点吝啬了,只是我的感觉而已,不多做评论了.

但是,毕竟有多一个选择也是不错的,呵呵.

取消电源按键的事件处理

之前的现象是在gnome-power-preferences里面,设置了”按下电源按钮时:”为”询问”.但是其实真的按下电源按钮的时候,gnome-power-manager的对话框确实出现了,但是根本来不及点,一闪而过的就关机了…
后来,TX告诉我是acpi搞的鬼,处理方法就是修改下 /etc/acpi/default.sh
打开此文件一看,就明白了,有这么一段:

case "$group" in
	button)
		case "$action" in
			power)
				/sbin/init 0
				;;

直接把 /sbin/init 0 那行注释掉,就好了,哈哈…

gnome-do 初体验

gnome-do最近的更新可谓热火朝天,而且最近搞出了个docky模式,貌似很好玩,使我的心里一直痒痒的.
但苦于这玩意是依赖mono的,之前一直不想装那么多包,所以一直没尝试.但是今天装一个以前ubuntu下用过的16进制编辑器Bless的时候,发现这个也是基于mono的,加上之前的tomboy,我不得不承认基于mono的软件还是挺多的,于是终于一股脑把这些都装上了,哈哈,系统里多了mono和一堆dev-dotnet的包.然后终于尝试到了gnome-do.
我的gnome-do是目前最新的0.7.98.启动以后,默认是经典样式的,在首选项里面可以改成docky模式.还是蛮好玩的,先上个图:
gnome-do
第一印象就是这个东西的美工真不错,说实话linux下很多软件的美工都不怎么样,但这个是例外,呵呵.
另外,在可用性上,还有很大的提升空间.super+space出来搜索界面以后,我输入”gnome-ter”都还不能出来”gnome-termial”,后来才知道,原来在中文环境下,要输入”终端”才能执行,那就汗了,我的fcitx在搜索窗口根本无效…而且这个关键字还不能自己定义,这样对中文用户来说,可用性就大打折扣了.
还有就是从panel拖启动器到dock的时候,有的图标会丢失,显示一个华丽的叉叉,哈哈.而且也不能自定义启动器的图标.
另外给个警示,但愿是我RP差的原因,我第一次启动gnome-do的时候,在首选项里面 勾了那个 “show notification icon”,然后画面就冻结了…除了鼠标能动,ctrl+alt+backspace都不能用了,还得我alt+printscreen+b才了事.但是后来又无法重现此问题…

mldonkey相关备忘

其实,比起 BT/ED2K/迅雷 等P2P的下载方式,我更喜欢传统的ftp. 但是ftp里面不是什么都能下载到的,最近想下载一些老电影,于是还是用上了mldonkey.
EE的blog里搜出来一些东西,不过这家伙的写东西基本上都看不懂而且也不能用的,呵呵,改了改,基本上好了.如下:
先是按需启动mlnet,建立一个 autostart.sh ,chmod +x 以后,加到gnome的会话里面(这样以后有其他需要自启动的东西也方便了),内容如下:

#!/bin/sh
ls ~/.mldonkey/temp/* >/dev/null 2>&1 && mlnet &

这样,只要有未下载完成的内容,都会在登录系统的时候打开mlnet,避免忘记开而浪费时间了.
另外,加这个alias到.bashrc,可以方便地查看下载状态:

alias m='pgrep mlnet >/dev/null 2>&1 && echo vd | nc -q 1 localhost 4000 | awk '"'"'/\[D/{print "\033[0;32m"$7"\t\033[4;31m"$8"%\033[0m\t",$14"KB/s"} /Down:/'"'"

效果如图:
alias效果

=======090121补充firefox关联ed2k到mldonkey的方法========
建立一个脚本文件(我的叫 ed2kml ),内容为:

#!/bin/sh
echo dllink $* | nc -q 1 127.0.0.1 4000

加上可执行权限,然后,firefox的地址栏里输入 about:config ,在里面新建一个布尔型的键,名字为 network.protocol-handler.external.ed2k ,值为true,再建一个字符串型键, 名为 network.protocol-handler.app.ed2k 值为 ed2kml 的绝对路径.
打开mldonkey以后,在firefox里点击一个ed2k链接,firefox会弹出一个选择连接的窗口,记住不要使用默认的,点”其他程序”,再定位到刚才的ed2kml,确定就可以了.可以勾选记住设置,以后就直接点链接就行了.

删了一堆 file-roller 的垃圾文件

linux用久了,也许你会发现家目录下有很多 .fr-***的文件夹,里面有很多你似曾相识的文件,但你又不知道是哪里来的.呵呵,其实那就是 file-roller 产生的临时文件.奇怪的是,按理这些临时文件应该在 /tmp 下才对的,不知道为什么会跑到家目录下,并留了下来.难道是老版本的 file-roller 留下的? 不知道大家的家目录下有没有这样的怪文件,反正我把它们都删了,哈哈.

SQLite简介

SQLite大致就是”SQL lite”,也就是一个微型的SQL解释器.它的赞助商和使用者包括mozilla,adobe,symbian等软件巨头,也算是来头不小了.
说它微型,那么它到底有多微型呢?我们可以看看它的可执行文件的大小,linux版本的打包文件是203.93 KiB,解压以后是350.88 KiB,是不是很微型呢?
除了微型之外,SQLite主要还要以下特点:

  • 无须配置: SQLite不需要安装,直接解压可执行文件即可运行.
  • 没有服务进程: SQLite无须通过TCP/IP等通信协议提交SQL到服务端,处理后再返回结果.
  • 单个数据文件: SQLite将用户数据存于单个普通文件里面.也就是说用户只要有数据文件的读权限,就可以读取所有数据;有写权限也能改变数据.
  • 数据文件可跨平台迁移: SQLite本身是跨平台的,它的数据文件同样也是跨平台的.数据文件和平台的字节序无关,也和CPU的位数无关.直接复制数据文件就可以实现数据迁移.
  • 紧凑: 如上所述,SQLite的运行环境非常小,如果在编译的时候去掉不需要的功能,可以减小至170KiB,用于嵌入式环境也是没问题的.
  • 松散数据类型: 不同于其他数据库的严格的数据类型检查,SQLite在尝试类型转换失败以后,允许在任何表的任何列里面插入任何类型的数据(一个例外是:整型的主键列里面只能存整型数据)
  • 变长的数据记录: 任何文本都是VARCHAR
  • 可读性很高的源码: 普通的程序员都能读懂,关键的变量和函数都有详细的注释.
  • SQL语句编译成虚拟机器语言: SQLite把SQL语句预编译成一种类似机器预言的代码,程序员可以方便得打印出代码及代码的执行结果,这样对debug很有好处.
  • 完全的公开: SQLite的源码可以任意下载使用,没有任何约束和版权(一些文档和测试代码是受开源license保护的).
  • SQL语言扩展: SQLite可以模块化地添加扩展,以增强其功能

说了这么多特点,那么,SQLite究竟怎么使用呢?
在一般的linux发行版下,安装 sqlite 这个包以后,就可以使用 sqlite3 这个命令来创建和处理数据库文件了.windows/DOS则下载这个文件解压到系统目录,mac则是下载这个文件.
安装完毕以后,就可以用

sqlite3 test.db

这个命令来创建一个空的数据库文件了.
然后,你可以用以下命令来建立一个含有两个列的表:

sqlite3 test.db "create table memos(text, priority INTEGER);"
sqlite3 test.db "insert into memos values('deliver project description', 10);"
sqlite3 test.db "insert into memos values('lunch with Christine', 100);"

然后可以这样查询出需要的数据:

sqlite3 test.db "select * from memos where priority>20;"
lunch with Christine|100

很简单吧~
下面展示一下,SQLite在C语言下的用法,同样用的是上面那个test.db,我们建立一个test.c,内容为:

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
#include <stdio.h>
#include <sqlite3.h>
 
static int callback(void *NotUsed, int argc, char **argv, char **azColName){
  int i;
  for(i=0; i<argc; i++){
    printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
  }
  printf("\n");
  return 0;
}
 
int main(int argc, char **argv){
  sqlite3 *db;
  char *zErrMsg = 0;
  char SQLbuffer[1024];
  int rc;
 
  if( argc!=2 ){
    fprintf(stderr, "Usage: %s num\n", argv[0]);
    return 1;
  }
  rc = sqlite3_open("test.db", &db);
  if( rc ){
    fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
    sqlite3_close(db);
    return 1;
  }
  sprintf(SQLbuffer, "select * from memos where priority > %s;", argv[1]);
  rc = sqlite3_exec(db, SQLbuffer, callback, 0, &zErrMsg);
  if( rc!=SQLITE_OK ){
    fprintf(stderr, "SQL error: %s\n", zErrMsg);
    sqlite3_free(zErrMsg);
  }
  sqlite3_close(db);
  return 0;
}

gcc -lsqlite3 test.c

进行编译,完成之后,执行

./a.out 30
text = lunch with Christine
priority = 100

怎么样,相当简单吧~

注: 文中部分内容翻译和参考自官方文档和man页.

新的dlmp3

两年多前,我写过一个自动下载百度mp3的脚本,后来百度曾经更换过几次页面结构,我也跟进维护了一段时间:,.
但再后来,由于觉得自动下的歌曲质量还是不如手工,加上已经有别人写的软件了,这脚本就丢那没管了.
直到昨天,收到 You Sheng 发来的邮件,说他还是比较喜欢那个脚本,百度改了页面之后又帮我修改了脚本,还写了个python来处理那凯撒加密,我觉得很感动,真的要谢谢他.
另外不禁感叹,难道这就是开源的力量?嘿嘿.
来自 You Sheng 的脚本可以在这里下载.

抓了所有中国手机号段的数据

由于工作需要,我最近要查询大量手机号码的归属地,而本地又没有手机号段-归属地的映射数据,所以随手写了行脚本,运行了N个小时后,终于抓回了166000行的数据.包括13*,151*,1530-1535,155-156,1571,158-159号段的归属地信息.因为据我考查,目前的所有手机号码都应该在以上号段里面,当前的仍在广告中的188和189号段的数据也都还查不到,以后出了,我想我会再更新的.
对了,数据来自手机在线,感谢一下.命令就简单的一行:

for i in `seq 1350000 1350009`; do echo $i `curl -s "http://api.showji.com/Locating/default.aspx?m=$i&output=json&callback=querycallback" | awk -F "[,:\"]+" '{if($9!="PostCode")print $7,$9,$11,$13,$15,$17}'`; done

改一下seq的值就可以得到不同段的结果,但不推荐再大号段地抓数据了,毕竟人家的服务器和流量也是要钱的,如果需要数据的话,从这里下载我抓好的,嘿嘿.

用notecase代替了tomboy

今天照常emerge -uDN world了,发现有一堆 dev-dotnet 的包要更新,而且几个包的关系错综复杂,理不出个头绪来,一执行,果然出错了,虽然不难解决,但是心里一直对.net和mono的不爽终于一下子爆发出来了:我干嘛为这个tomboy装那么一大堆的依赖包呢? 虽然tomboy很方便很好用,而且速度也很快,但是我觉得还没有必要到装整个mono环境的地步.再说我里面也就只有几条记录而已.
于是狠下心来删了tomboy,depclean了一堆包,那个爽啊~~哈哈…
用上 oceanboo 给我推荐的 notecase ,基本也能满足我的需求了,不就记点事,然后可以缩到系统托盘,这样就和原来tomboy的applet模式差不多了.不过新建的时候麻烦一点,呵呵.
难道要自己写个tomboy用?