关注小众语言、AI技术,记录、分享技术点滴!

0%

查看python的版本

1
2
python -V
Python 2.6.6

1.下载Python-2.7.3

1
wget http://python.org/ftp/python/2.7.3/Python-2.7.3.tar.bz2

2.解压Python-2.7.3

1
tar -jxvf Python-2.7.3.tar.bz2

3.进入刚解压后的文件夹(可使用命令)

1
cd Python-2.7.3

4.安装

1
2
3
4
5
./configure
make all
make install
make clean
make distclean

5.查看版本信息

1
/wp-content/local/bin/python2.7 -V

6.建立软连接,使系统默认的python指向python2.7
正常情况下即使python2.7安装成功后,系统默认指向的python仍然是2.6.6版本,考虑到yum是基于python2.6.6才能正常工作,不敢轻易卸载。

如何实现将系统默认的python指向到2.7版本呢?

1
2
mv /wp-content/bin/python /wp-content/bin/python2.6.6
ln -s /wp-content/local/bin/python2.7 /wp-content/bin/python

检验python指向是否成功

1
python -V

7.解决系统python软链接指向python2.7版本后,yum不能正常工作

1
2
3
4
5
vi /wp-content/bin/yum
将文件头部的
#!/wp-content/bin/python
改成
#!/wp-content/bin/python2.6.6

整个升级过程完成,可以使用Python2.7.3版本了。

time有计时作用,dd用于复制,从if读出,写到of。if=/dev/zero不产生IO,因此可以用来测试纯写速度。同理of=/dev/null不产生IO,可以用来测试纯读速度。bs是每次读或写的大小,即一个块的大小,count是读写块的数量。

1.测/目录所在磁盘的纯写速度:

1
2
dd if=/dev/zero of=1Gb.file bs=1k count=1000000
time sh -c "dd if=/dev/zero of=1Gb.file bs=1k count=1000000; sync"

2.测/目录所在磁盘的纯读速度:

1
2
dd if=1Gb.file bs=64k |dd of=/dev/null
time sh -c "dd if=1Gb.file bs=64k |dd of=/dev/null; sync"

3.测读写速度:

1
2
dd if=1Gb.file of=2Gb.file bs=64k
time sh -c "dd if=1Gb.file of=2Gb.file bs=64k; sync"

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
//本周第一天 
function weekFirstDay($time=null) {
$time = ($time==null) ? time() : $time;
return date('Y-m-d', $time-86400*(date('N',$time)-1));
}
//本月第一天
function monthFirstDay() {
return date('Y-m-d', mktime(0,0,0,date('n'),1,date('Y')));
}
//本季度第一天
function quarterFirstDay() {
return date('Y-m-d', mktime(0,0,0,date('n')-(date('n')-1)%3,1,date('Y')));
}
//本年第一天
function yearFirstDay() {
return date('Y').'-01-01';
}

Sublime Text 2 一款优化的代码开发工具,可算是一款小型的IDE工具,支持WIN,MAC,LINUX等操作系统,有丰富的工具包,可以通过Package管理工具进行各种扩展包安装,类似Eclipse中的Plug-in,同时该工具免费使用,无须支持免费当然偶尔会有付费提示,可不理会继续使用。

下载地址:http://www.sublimetext.com/

汉化语言包:http://download.csdn.net/detail/shisdq/4398263

注册补丁下载:http://download.csdn.net/detail/shisdq/4398223

注:文章中提供相关的工具,如有涉及到版权等相关问题均与作者无关,只做测试使用,禁止传播!

此种技术一般使用在大型的UI系统开发中: 主要用于核心开发者了为了让 各类普通开发人员能方便调用自己的方法(事件).. 下面是相关示例: 核心开发者,负责拖动事件的JS书写.. 普通开发人员或者美工,只需制作HTML排版…并加上 核心开发者定义的自定义属性后,就能实现拖动. 微软IE中的document.attachEvent为我们提供了良好的自定义事件能力.. 本实例中的自定义属性为:eDrag 通过自定义属性来激活自定义事件..

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
var __DragId, __eDragSrc, __DragTop, __DragLeft;
function __OnDrag(){
var _element = event.srcElement;
if(_element.eDrag){
if(event.type=="mousedown"){
if(_element.eDragSrc){
__eDragSrc = document.getElementById(_element.eDragSrc);
__eDragSrc.style.display = "block";
}
document.body.style.cursor = "default";
__DragId = document.getElementById(_element.eDrag);
__DragLeft = parseInt(__DragId.offsetWidth)-(parseInt(__DragId.offsetWidth)-(event.x-parseInt(__DragId.offsetLeft)));
__DragTop = parseInt(__DragId.offsetHeight)-(parseInt(__DragId.offsetHeight)-(event.y-parseInt(__DragId.offsetTop)));
}
if(event.type=="mouseup"){
if(__DragId){
__DragId = null;
}
if(__eDragSrc){
__eDragSrc.style.display = "none";
__eDragSrc = null;
}
}
}
if(event.type=="mousemove"){
if(__DragId){
__DragId.style.top = event.y - __DragTop;
__DragId.style.left = event.x - __DragLeft;
__DragId.style.margin = "auto";
}
}
}
document.attachEvent("onmousedown", __OnDrag);
document.attachEvent("onmousemove", __OnDrag);
document.attachEvent("onmouseup", __OnDrag);

JavaScript 的成功让人津津乐道,为 Web 网页编写 JavaScript 代码已经是所有 Web 设计师的基本功,这门有趣的语言蕴藏着许多不为人熟知的东西,即使多年的 JavaScript 程序员,也未能完全吃透。本文从7个方面讲述 JavaScript 中那些你不很熟知但非常实用的技巧。

简略语句
JavaScript 可以使用简略语句快速创建对象和数组,比如下面的代码:

1
2
3
4
5
var car = new Object();  
car.colour = 'red';
car.wheels = 4;
car.hubcaps = 'spinning';
car.age = 4;

可以使用简略语句如下:

1
2
3
4
5
6
var car = {
colour:'red',
wheels:4,
hubcaps:'spinning',
age:4
}

对象 car 就此创建,不过需要特别注意,结束花括号前一定不要加 “;” 否则在 IE 会遇到很大麻烦。

创建数组的传统方法是:

1
2
3
var moviesThatNeedBetterWriters = new Array(
'Transformers','Transformers2','Avatar','Indiana Jones 4'
);

使用简略语句则:

1
2
3
var moviesThatNeedBetterWriters = [
'Transformers','Transformers2','Avatar','Indiana Jones 4'
];

另一个可以使用简略语句的地方是条件判断语句:

1
2
var direction;  
if(x < 200){ direction = 1; } else { direction = -1; }

可以简略为:

1
var direction = x < 200 ? 1 : -1;

JSON 数据格式
JSON 是 “JavaScript Object Notation” 的缩写,由 Douglas Crockford 设计,JSON 改变了 JavaScript 在缓存复杂数据格式方面的困境,如下例,假如你要描述一个乐队,可以这样写:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
var band = {  
"name":"The Red Hot Chili Peppers",
"members":[
{
"name":"Anthony Kiedis",
"role":"lead vocals"
},
{
"name":"Michael 'Flea' Balzary",
"role":"bass guitar, trumpet, backing vocals"
},
{
"name":"Chad Smith",
"role":"drums,percussion"
},
{
"name":"John Frusciante",
"role":"Lead Guitar"
}
],
"year":"2009"
}

你可以在 JavaScript 中直接使用 JSON,甚至作为某些 API 的返回数据对象,以下代码调用著名书签网站 delicious.com 的一个 API,返回你在该网站的所有书签,并显示在你自己的网站:

JavaScript 本地函数 (Math, Array 和 String)
JavaScript 有很多内置函数,有效的使用,可以避免很多不必要的代码,比如,从一个数组中找出最大值,传统的方法是:

1
2
3
4
5
6
7
8
var numbers = [3,342,23,22,124];  
var max = 0;
for(var i=0;i<numbers.length;i++){
if(numbers[i]=""> max){
max = numbers[i];
}
}
alert(max);

使用内置函数可以更容易实现:

1
2
3
var numbers = [3,342,23,22,124];  
numbers.sort(function(a,b){return b - a});
alert(numbers[0]);

另一个方法是使用 Math.max() 方法:

1
Math.max(12,123,3,2,433,4); // returns 433

你可以用这个方法帮助探测浏览器

1
2
3
4
var scrollTop= Math.max(  
doc.documentElement.scrollTop,
doc.body.scrollTop
);

这解决了 IE 浏览器的一个问题,通过这种方法,你总是可以找到那个正确的值,因为浏览器不支持的那个值会返回 undefined。

还可以使用 JavaScript 内置的 split() 和 join() 函数处理 HTML 对象的 CSS 类名,如果 HTML 对象的类名是空格隔开的多个名字,你在为它追加或删除一个 CSS 类名的时候需要特别注意,如果该对象还没有类名属性,可以直接将新的类名赋予它,如果已经存在类名,新增的类名前必须有一个空格,用传统的 JavaScript 方法是这样实现的:

1
2
3
4
function addclass(elm,newclass){  
var c = elm.className;
elm.className = (c === '') ? newclass : c+' '+newclass;
}

使用 split 和 join 方法则直观优雅得多:

1
2
3
4
5
function addclass(elm,newclass){  
var classes = elm.className.split(' ');
classes.push(newclass);
elm.className = classes.join(' ');
}

事件代理
与其在 HTML 文档中设计一堆事件,不如直接设计一个事件代理,举例说明,假如你有一些链接,用户点击后不想打开链接,而是执行某个事件,HTML 代码如下:

Great Web resources

使用事件代理,可以直接处理,无需遍历:

1
2
3
4
5
6
7
8
9
10
11
(function(){
var resources = document.getElementById('resources');
resources.addEventListener('click',handler,false);
function handler(e){
var x = e.target; // get the link tha
if(x.nodeName.toLowerCase() === 'a'){
alert('Event delegation:' + x);
e.preventDefault();
}
};
})();

匿名函数与 Module 模式
JavaScript 的一个问题是,任何变量,函数或是对象,除非是在某个函数内部定义,否则,就是全局的,意味着同一网页的别的代码可以访问并改写这个变量(ECMA 的 JavaScript 5 已经改变了这一状况 - 译者),使用匿名函数,你可以绕过这一问题。

比如,你有这样一段代码,很显然,变量 name, age, status 将成为全局变量

1
2
3
4
5
6
7
8
9
var name = 'Chris';  
var age = '34';
var status = 'single';
function createMember(){
// [...]
}
function getMemberDetails(){
// [...]
}

为了避免这一问题,你可以使用匿名函数:

1
2
3
4
5
6
7
8
9
10
11
 var myApplication = function(){  
var name = 'Chris';
var age = '34';
var status = 'single';
function createMember(){
// [...]
}
function getMemberDetails(){
// [...]
}
}();

如果这个函数不会被调用,可以更直接为:

1
2
3
4
5
6
7
8
9
10
11
 (function(){  
var name = 'Chris';
var age = '34';
var status = 'single';
function createMember(){
// [...]
}
function getMemberDetails(){
// [...]
}
})();

如果要访问其中的对象或函数,可以:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
var myApplication = function(){
var name = 'Chris';
var age = '34';
var status = 'single';
return{
createMember:function(){
// […]
},
getMemberDetails:function(){
// […]
}
}
}();
// myApplication.createMember() and
// myApplication.getMemberDetails() now works.

这就是所谓 Module 模式或单例模式(Singleton),该模式为 Douglas Crockford 所推崇,并被大量应用在 Yahoo User Interface Library YUI。

假如你想在别的地方调用里面的方法,又不想在调用前使用 myApplication 这个对象名,可以在匿名函数中返回这些方法,甚至用简称返回:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
var myApplication = function(){
var name = 'Chris';
var age = '34';
var status = 'single';
function createMember(){
// […]
}

function getMemberDetails(){
// […]
}
return{
create:createMember,
get:getMemberDetails
}
}();
//myApplication.get() and myApplication.create() now work.

代码配置
别人使用你编写的 JavaScript 代码的时候,难免会更改某些代码,但这会很困难,因为不是每个人都很容易读懂别人的代码,与其这样,不如创建一个代码配置对象,别人只需要在这个对象中更改某些配置即可实现代码的更改。这里有一篇 JavaScript 配置对象详解的文章,简单说:

在代码中创建一个叫做 configuration 的对象
里面保存所有可以更改的配置,如 CSS ID 和类名,按钮的标签文字,描述性文字,本地化语言设置
将该对象设置为全局对象,以便别人直接访问并改写

你应当在最后一步做这项工作,这里有一个文章,交付代码前的5件事值的参考。
同后台交互
JavaScript 是一门前台语言,你需要别的语言同后台交互,并返回数据,使用 AJAX,你可以让 JavaScript 直接使用同后台的交互,将复杂的数据处理交由后台处理。
JavaScript 框架
自己编写适应各种浏览器的代码是完全浪费时间,应当选择一个 JavaScript 框架,让这些复杂的事情交给框架处理。

非常简单,记录一下:

1
2
3
4
5
6
$begin= explode(' ', microtime());

//php script here

$end = explode(' ', microtime());
echo ($end[1]-$begin[1]).'s'.($end[0]-$begin[0]).'ms';

我习惯使用PATH_INFO的方式来实现搜索引擎友好,比如:

http://www.xxx.com/index.php/module/xxx/action/xxx/id/xxx

但是index.php能看到扩展名很不爽,解决方法如下:

如何隐蔽应用:例如 .php,的扩展名:

在APACHE中这样配置:

ForceType application/x-httpd-php

如何更像静态页面:app_name/my/app.html

解析的PATH_INFO参数的时候,把最后一个参数的最后5个字符“.html”截断即可。

注意:APACHE2中缺省是不允许PATH_INFO的,需要设置 AcceptPathInfo on

http://www.xxx.com/index/module/xxx/action/xxx/id/xxx

SQLite是遵守ACID的关联式数据库管理系统,它包含在一个相对小的C库中。它是D.RichardHipp建立的公有领域项目。

  该版本增加了 sqlite3_create_function_v2() 接口,用以处理析构器(destructor)的回调;通过使用应用提供的回调函数来定义查询区域的边界以增加对自定义 r-tree 查询;默认的页缓存努力避免内存分配大于预设SQLITE_CONFIG_PAGECACHE的值等。

下载地址:http://www.sqlite.org/download.html