基本VIM 操作指令(一)

2011年1月4日 没有评论

§ 进入输入模式

在命令模式下输入以下指令,程式将会进入输入(insert)模式
此时使用者便可以修改文件档,
若想跳出输入模式,则键入<ESC>即可回到命令模式。

i
在游标左方进入输入模式

I
在游标所在行的行首进入输入模式

a
在游标右方进入输入模式

A
在游标所在行的行尾进入输入模式

o (小写英文字母o)
在游标下一行另起新行,并进入输入模式

O (大写英文字母o)
在游标上一行另起新行,并进入输入模式


§ 移动游标

k
向上移动游标一个字元
也就是方向键的「↑」

j
向下移动游标一个字元
也就是方向键的「↓」

h
向左移动游标一个字元
也就是方向键的「←」

l
向右移动游标一个字元
也就是方向键的「→」

H
将游标移至萤幕顶端

M
将游标移至萤幕中央

L
将游标移至萤幕底端

:数字
将游标移至档案第 数字
如输入 :45 ,即移动至档案第45行

数字 G
将游标移至档案第 数字
如输入 45G ,即移动至档案第45行

gg
将游标移至档案第一行

G
将游标移至档案最后一行

b
移动游标至该单字的第一个字母
若该处已是该单字第一个字母,则游标会移至前一个单字的第一个字母

e
移动游标至该单字的最后一个字母
若该处已是该单字最后一个字母,则游标会移至下一个单字的最后一个字母

w
移动游标至下一个单字的第一个字母

^
移动游标至该行第一个非空白字母


§ 卷动视窗

<ctrl>+f
将视窗向下卷动一半

<ctrl>+b
将视窗向上卷动一半

<ctrl>+d
将视窗往下卷动一页
功能类似键盘中的<PageDown>

<ctrl>+u
将视窗往上卷动一页
功能类似键盘中的<PageUp>


§ 搜寻文字

/字串
向下搜寻字串
下达此命令之后,若文件中包含该「 字串 」,则文件中所有「 字串 」的背景颜色会被置换成较鲜明的颜色,在下达完搜寻指令之后,还可以透过「 n 」和「 N 」指令作进一步控制。
n 跳到下一个「 字串 」所在地
N 跳到上一个「 字串 」所在地
另外,把游标停在想要搜寻的字串上,按下「 * 」也可以达到向下搜寻的效果。

?字串
向上搜寻字串
下达此命令之后,若文件中包含该「 字串 」,则文件中所有「 字串 」的背景颜色会被置换成较鲜明的颜色,在下达完搜寻指令之后,还可以透过「 n 」和「 N 」指令作进一步控制。
n 跳到上一个「 字串 」所在地
N 跳到下一个「 字串 」所在地
另外,把游标停在想要搜寻的字串上,按下「 # 」也可以达到向上搜寻的效果。

分类: Linux 标签:

PHP静态属性和静态方法

2011年1月4日 没有评论
<?php

class Math
{
public static $PI=3.14;
//定义静态属性

//public $PI=3.14; //静态方法不能调用非静态的属性

//定义一个静态方法,求两个数中的最大值 public static function getMax($num1,$num2){

//static 关键字 return $num1 > $num2 ? $num1 : $num2;
}

//定义一个静态方法,求圆面积 public static function getCircleArea($radius){

//return Math::$PI * $radius * $radius;//也行 return self::$PI * $radius * $radius;

//建议

//用self::调用当前类中的静态属性 }

// 求三个数中的最大值,用self::调用当前类中其它静态方法 public static function getMax3($num1,$num2,$num3){
$num1 = self::getMax($num1,$num2);
$num2 = self::getMax($num2,$num3);
$num1 = self::getMax($num1,$num2);

//或$num1 = Math::getMax($num1,$num2); return $num1;
}
}

 

//———————————————————–$a=1;
$b=2;
echo “最大值:”;
echo Math::getMax($a,$b);

//注意使用方法, 类名::静态方法名echo “<br>”;

//———————————————————–$r=2;
echo “半径为{$r}的圆的面积为”.Math::getCircleArea($r);
echo “<br>”;

//————————————————————$a=1;$b=2;$c=3;
echo “{$a},{$b},{$c}三个数中的最大值是” .Math::getMax3($a,$b,$c);

?>

分类: PHP 标签:

Linux Grep命令学习

2010年12月31日 没有评论

1. grep简介

grep (global search regular expression_r(RE) and print out the line,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。Unix的grep家族包括grep、egrep和fgrep。egrep和fgrep的命令只跟grep有很小不同。egrep是grep的扩展,支持更多的re元字符, fgrep就是fixed grep或fast grep,它们把所有的字母都看作单词,也就是说,正则表达式中的元字符表示回其自身的字面意义,不再特殊。Linux使用GNU版本的grep。它功能更强,可以通过-G、-E、-F命令行选项来使用egrep和fgrep的功能。

grep的工作方式是这样的,它在一个或多个文件中搜索字符串模板。如果模板包括空格,则必须被引用,模板后的所有字符串被看作文件名。搜索的结果被送到屏幕,不影响原文件内容。

grep可用于shell脚本,因为grep通过返回一个状态值来说明搜索的状态,如果模板搜索成功,则返回0,如果搜索不成功,则返回1,如果搜索的文件不存在,则返回2。我们利用这些返回值就可进行一些自动化的文本处理工作。

2. grep正则表达式元字符集(基本集)

^

锚定行的开始 如:’^grep’匹配所有以grep开头的行。

$

锚定行的结束 如:’grep$’匹配所有以grep结尾的行。

匹配一个非换行符的字符 如:’gr.p’匹配gr后接一个任意字符,然后是p。

*

匹配零个或多个先前字符 如:’*grep’匹配所有一个或多个空格后紧跟grep的行。 .*一起用代表任意字符。

[]

匹配一个指定范围内的字符,如’[Gg]rep’匹配Grep和grep。

[^]

匹配一个不在指定范围内的字符,如:’[^A-FH-Z]rep’匹配不包含A-R和T-Z的一个字母开头,紧跟rep的行。

(..)

标记匹配字符,如’(love)’,love被标记为1。

<

锚定单词的开始,如:’

>

锚定单词的结束,如’grep>’匹配包含以grep结尾的单词的行。

x

重复字符x,m次,如:’0′匹配包含5个o的行。

x

重复字符x,至少m次,如:’o'匹配至少有5个o的行。

x

重复字符x,至少m次,不多于n次,如:’o'匹配5–10个o的行。

w

匹配文字和数字字符,也就是[A-Za-z0-9],如:’Gw*p’匹配以G后跟零个或多个文字或数字字符,然后是p。

W

w的反置形式,匹配一个或多个非单词字符,如点号句号等。

b

单词锁定符,如: ‘bgrepb’只匹配grep。

3. 用于egrep和 grep -E的元字符扩展集

+

匹配一个或多个先前的字符。如:’[a-z]+able’,匹配一个或多个小写字母后跟able的串,如loveable,enable,disable等。

?

匹配零个或多个先前的字符。如:’gr?p’匹配gr后跟一个或没有字符,然后是p的行。

a|b|c

匹配a或b或c。如:grep|sed匹配grep或sed

()

分组符号,如:love(able|rs)ov+匹配loveable或lovers,匹配一个或多个ov。

x,x,x

作用同x,x,x

4. POSIX字符类

为了在不同国家的字符编码中保持一至,POSIX(The Portable Operating System Interface)增加了特殊的字符类,如[:alnum:]是A-Za-z0-9的另一个写法。要把它们放到[]号内才能成为正则表达式,如[A- Za-z0-9]或[[:alnum:]]。在Linux下的grep除fgrep外,都支持POSIX的字符类。

[:alnum:]

文字数字字符

[:alpha:]

文字字符

[:digit:]

数字字符

[:graph:]

非空字符(非空格、控制字符)

[:lower:]

小写字符

[:cntrl:]

控制字符

[:print:]

非空字符(包括空格)

[:punct:]

标点符号

[:space:]

所有空白字符(新行,空格,制表符)

[:upper:]

大写字符

[:xdigit:]

十六进制数字(0-9,a-f,A-F)

5. Grep命令选项

-?

同时显示匹配行上下的?行,如:grep -2 pattern filename同时显示匹配行的上下2行。

-b,–byte-offset

打印匹配行前面打印该行所在的块号码。

-c,–count

只打印匹配的行数,不显示匹配的内容。

-f File,–file=File

从文件中提取模板。空文件中包含0个模板,所以什么都不匹配。

-h,–no-filename

当搜索多个文件时,不显示匹配文件名前缀。

-i,–ignore-case

忽略大小写差别。

-q,–quiet

取消显示,只返回退出状态。0则表示找到了匹配的行。

-l,–files-with-matches

打印匹配模板的文件清单。

-L,–files-without-match

打印不匹配模板的文件清单。

-n,–line-number

在匹配的行前面打印行号。

-s,–silent

不显示关于不存在或者无法读取文件的错误信息。

-v,–revert-match

反检索,只显示不匹配的行。

-w,–word-regexp

如果被<和>引用,就把表达式做为一个单词搜索。

-V,–version

显示软件版本信息。

6. 实例

要用好grep这个工具,其实就是要写好正则表达式,所以这里不对grep的所有功能进行实例讲解,只列几个例子,讲解一个正则表达式的写法。

$ ls -l | grep ‘^a’

通过管道过滤ls -l输出的内容,只显示以a开头的行。

$ grep ‘test’ d*

显示所有以d开头的文件中包含test的行。

$ grep ‘test’ aa bb cc

显示在aa,bb,cc文件中匹配test的行。

$ grep ‘[a-z]‘ aa

显示所有包含每个字符串至少有5个连续小写字符的字符串的行。

$ grep ‘w(es)t.*’ aa

如果west被匹配,则es就被存储到内存中,并标记为1,然后搜索任意个字符(.*),这些字符后面紧跟着另外一个es(),找到就显示该行。如果用egrep或grep -E,就不用”"号进行转义,直接写成’w(es)t.*’就可以了。

分类: Linux 标签:

PDO的使用入门

2010年12月29日 没有评论

PDO(PHP Data Object) 是PHP 5新出来的东西,在PHP 6都要出来的时候,PHP 6只默认使用PDO来处理数据库,将把所有的数据库扩展移到了PECL,那么默认就是没有了我们喜爱的php_mysql.dll之类的了,那怎么办捏,我们只有与时俱进了,我就小试了一把PDO。(本文只是入门级的,高手可以略过,呵呵)
【PDO是啥】

PDO是PHP 5新加入的一个重大功能,因为在PHP 5以前的php4/php3都是一堆的数据库扩展来跟各个数据库的连接和处理,什么php_mysql.dllphp_pgsql.dllphp_mssql.dllphp_sqlite.dll等等扩展来连接MySQLPostgreSQLMS SQL ServerSQLite,同样的,我们必须借助 ADOdbPEAR::DBPHPlib::DB之类的数据库抽象类来帮助我们,无比烦琐和低效,毕竟,php代码的效率怎么能够我们直接用C/C++写的扩展斜率高捏?所以嘛,PDO的出现是必然的,大家要平静学习的心态去接受使用,也许你会发现能够减少你不少功夫哦。

 

【安装PDO】

我是在Windows XP SP2 上面,所以嘛,整个过程都是在Windows行进行的啦,至于Linux/FreeBSD 等平台,请自行查找资料设置安装。
我的是PHP 5.1.4,已经自带有了php_pdo.dll的扩展,不过需要稍微设置一下才能使用。

打开 c:\windows\php.ini ,那是我的PHP配置文件,找到下面这行:
extension_dir
这个就是我们扩展存在的目录,我的PHP 5扩展是在:C:\php5\ext,那么我就把这行改成:

extension_dir = “C:/php5/ext”

然后再往php.ini下面找到:

;;;;;;;;;;;;;;;;;;;;;;
; Dynamic Extensions ;
;;;;;;;;;;;;;;;;;;;;;;

下面有一堆类似 ;extension=php_mbstring.dll 的东西,这里就是PHP扩展加载的配置了,我们再最后面添加上我们PDO的扩展:

extension=php_pdo.dll
extension=php_pdo_mysql.dll
extension=php_pdo_pgsql.dll
extension=php_pdo_sqlite.dll
extension=php_pdo_mssql.dll
extension=php_pdo_odbc.dll
extension=php_pdo_firebird.dll
;extension=php_pdo_oci8.dll

各种PDO的驱动,能给加上的全给加上,不过后面的php_pdo_oci8.dll,因为我没有安装Oralce数据库,所以没有这个,就使用分号注释掉它。然后重启我们的Web服务器, IIS/Apache,我的是IIS,嘿嘿,表鄙视我,在Windows上,简单嘛。
重启后,在我们Web服务器的文档目录下写一个phpinfo.php的文件,加上这些:

<?
phpinfo();
?>

然后打开我们可爱的浏览器:IE/FireFox,我的是FireFox 2.0,刚下载的,很爽,不怕流氓软件,哈哈。
在浏览器里面输入:http://localhost/phpinfo.php,如果你的这个页面路径不一致,请自行输入。
输出的内容中,如果你能够顺利的看到:

PDO
PDO support enabled
PDO drivers mysql, pgsql, sqlite, mssql, odbc, firebird

后面有各种驱动的说明,
PDO_Firebird,pdo_mssql,pdo_mysql,PDO_ODBC,pdo_pgsql,pdo_sqlite

那么,恭喜你安装成功了,否则请仔细检查上面的步骤。

 

【牛刀小小试验】

我用的是MySQL 4.0.26,但是我个人推荐大家使用 MySQL 4.1.x 或者 MySQL 5.0.x,因为那些版本有很多有趣的东西值得去学习。我们这里PDO需要连接的就是我的MySQL 4.0啦,如果你没有安装MySQL,请自行安装。我们建立好了MySQL,并且在test库里添加了表foo,包括 id,name,gender,time等四个字段。

我们开始构造第一个PDO应用,建立一个pdo.php文件在Web文档目录下:

 

<?php
$dsn = “mysql:host=localhost;dbname=test”;
$db = new PDO($dsn, ‘root’, ”);
$count = $db->exec(“INSERT INTO foo SET name = ‘heiyeluren’,gender=’男’,time=NOW()”);
echo $count;
$db = null;
?>

 

不明白啥意思,俺们来慢慢讲讲。这行:
$dsn = “mysql:host=localhost;dbname=test”;
就是构造我们的DSN(数据源),看看里面的信息包括:数据库类型是mysql,主机地址是localhost,数据库名称是test,就这么几个信息。不同数据库的数据源构造方式是不一样的。

$db = new PDO($dsn, ‘root’, ”);
初始化一个PDO对象,构造函数的参数第一个就是我们的数据源,第二个是连接数据库服务器的用户,第三个参数是密码。我们不能保证连接成功,后面我们会讲到异常情况,这里我们姑且认为它是连接成功的。

$count = $db->exec(“INSERT INTO foo SET name = ‘heiyeluren’,gender=’男’,time=NOW()”);
echo $count;
调用我们连接成功的PDO对象来执行一个查询,这个查询是一个插入一条记录的操作,使用PDO::exec() 方法会返回一个影响记录的结果,所以我们输出这个结果。最后还是需要结束对象资源:
$db = null;

默认这个不是长连接,如果需要数据库长连接,需要最后加一个参数:array(PDO::ATTR_PERSISTENT => true) 变成这样:
$db = new PDO($dsn, ‘root’, ”, array(PDO::ATTR_PERSISTENT => true));

一次操作就这么简单,也许跟以前的没有太大区别,跟ADOdb倒是有几分相似。

 

【继续了解】

如果我们想提取数据的话,那么就应该使用数据获取功能。(下面用到的$db都是上面已经连接好的对象)

<?php
foreach($db->query(“SELECT * FROM foo”)){
print_r($row);
}
?>

我们也可以使用这种获取方式:

<?php
$rs = $db->query(“SELECT * FROM foo”);
while($row = $rs->fetch()){
print_r($row);
}
?>

如果想一次把数据都获取到数组里可以这样:

<?php
$rs = $db->query(“SELECT * FROM foo”);
$result_arr = $rs->fetchAll();
print_r($result_arr);
?>

 

输出:

 

Array
(
[0] => Array
(
[id] => 1
[0] => 1
[name] => heiyeluren
[1] => heiyeluren
[gender] =>
[2] =>
[time] => 2006-10-28 23:14:23
[3] => 2006-10-28 23:14:23
)
}

我们看里面的记录,数字索引和关联索引都有,浪费资源,我们只需要关联索引的:

<?php
$db->setAttribute(PDO::ATTR_CASE, PDO::CASE_UPPER);
$rs = $db->query(“SELECT * FROM foo”);
$rs->setFetchMode(PDO::FETCH_ASSOC);
$result_arr = $rs->fetchAll();
print_r($result_arr);
?>

看上面的代码,setAttribute() 方法是设置部分属性,主要属性有:PDO::ATTR_CASE、PDO::ATTR_ERRMODE等等,我们这里需要设置的是PDO::ATTR_CASE,就是我们使用关联索引获取数据集的时候,关联索引是大写还是小写,有几个选择:

PDO::CASE_LOWER – 强制列名是小写
PDO::CASE_NATURAL – 列名按照原始的方式
PDO::CASE_UPPER – 强制列名为大写

我们使用setFetchMode方法来设置获取结果集的返回值的类型,同样类型还有:

PDO::FETCH_ASSOC – 关联数组形式
PDO::FETCH_NUM – 数字索引数组形式
PDO::FETCH_BOTH – 两者数组形式都有,这是缺省的
PDO::FETCH_OBJ – 按照对象的形式,类似于以前的 mysql_fetch_object()

当然,一般情况下我们是使用PDO::FETCH_ASSOC,具体使用什么,按照你自己的需要,其他获取类型参考手册。
除了上面这种获取数据的方式,还有这种:

<?php
$rs = $db->prepare(“SELECT * FROM foo”);
$rs->execute();
while($row = $rs->fetch()){
print_r($row);
}
?>

其实差不多啦。如果你想获取指定记录里一个字段结果的话,可以使用 PDOStatement::fetchColumn():

<?php
$rs = $db->query(“SELECT COUNT(*) FROM foo”);
$col = $rs->fetchColumn();
echo $col;
?>

一般使用fetchColumn()来进行count统计或者某些只需要单字段的记录很好操作。
简单的总结一下上面的操作:

查询操作主要是PDO::query()、PDO::exec()、PDO::prepare()。PDO::query()主要是用于有记录结果返回的操作,特别是SELECT操作,PDO::exec()主要是针对没有结果集合返回的操作,比如INSERT、UPDATE、DELETE等操作,它返回的结果是当前操作影响的列数。PDO::prepare()主要是预处理操作,需要通过$rs->execute()来执行预处理里面的SQL语句,这个方法可以绑定参数,功能比较强大,不是本文能够简单说明白的,大家可以参考手册和其他文档。

获取结果集操作主要是:PDOStatement::fetchColumn()、PDOStatement::fetch()、PDOStatement::fetchALL()。PDOStatement::fetchColumn() 是获取结果指定第一条记录的某个字段,缺省是第一个字段。PDOStatement::fetch() 是用来获取一条记录,PDOStatement::fetchAll()是获取所有记录集到一个中,获取结果可以通过PDOStatement::setFetchMode来设置需要结果集合的类型。

另外有两个周边的操作,一个是PDO::lastInsertId()和PDOStatement::rowCount()。PDO::lastInsertId()是返回上次插入操作,主键列类型是自增的最后的自增ID。PDOStatement::rowCount()主要是用于PDO::query()和PDO::prepare()进行DELETE、INSERT、UPDATE操作影响的结果集,对PDO::exec()方法和SELECT操作无效。

 

【错误处理】

如果程序中碰到错误咋办?我们这里描述PDO类的错误信息和异常处理。

1. 面向对象的方式

先看看如果连接错误等的处理,使用面向对象的方式来处理:

<?php
try {
$db = new PDO(‘mysql:host=localhost;dbname=test’, $user, $pass);
$db = null;
} catch (PDOException $e) {
print “Error: . $e->getMessage() . “<br/>”;
die();
}
?>

 

这里利用我们PHP 5面向对象的异常处理特征,如果里面有异常的话就初始化调用PDOException来初始化一个异常类。
PDOException异常类的属性结构:

 

<?php
class PDOException extends Exception
{
public $errorInfo = null; // 错误信息,可以调用 PDO::errorInfo() 或 PDOStatement::errorInfo()来访问
protected $message; // 异常信息,可以试用 Exception::getMessage() 来访问
protected $code; // SQL状态错误代码,可以使用 Exception::getCode() 来访问
}
?>

 

这个异常处理类是集成PHP 5内置的异常处理类,我们简单的看一下PHP 5内置的异常处理类结构:

<?php
class Exception
{
// 属性
protected $message = ‘Unknown exception’; // 异常信息
protected $code = 0; // 用户自定义异常代码
protected $file; // 发生异常的文件名
protected $line; // 发生异常的代码行号

// 方法
final function getMessage(); // 返回异常信息
final function getCode(); // 返回异常代码
final function getFile(); // 返回发生异常的文件名
final function getLine(); // 返回发生异常的代码行号
final function getTrace(); // backtrace() 数组
final function getTraceAsString(); // 已格成化成字符串的 getTrace() 信息
}
?>


相应的,在代码中可以合适的调用 getFile() getLine() 来进行错误定位,更方便的进行调试。
2. 使用面向过程的方法
先看代码:

<?
$db = new PDO(‘mysql:host=localhost;dbname=test’, $user, $pass);
$rs = $db->query(“SELECT aa,bb,cc FROM foo”);
if ($db->errorCode() != ’00000′){
print_r($db->errorInfo());
exit;
}
$arr = $rs->fetchAll();
print_r($arr);
$db = null;
?>

PDO和PDOStatement对象有errorCode() errorInfo() 方法,如果没有任何错误, errorCode() 返回的是: 00000 ,否则就会返回一些错误代码。errorInfo() 返回的一个数组,包括PHP定义的错误代码和MySQL的错误代码和错误信息,数组结构如下:

Array
(
[0] => 42S22
[1] => 1054
[2] => Unknown column ‘aaa’ in ‘field list’
)

 

每次执行查询以后,errorCode() 的结果都是最新的,所以我们可以很容易自己控制错误信息显示。

 

【简单总结】

从上面的使用看出,PDO功能确实强大,另外还有一些内容我没有讲到,比如绑定参数、预处理、存储过程、事务处理等等功能。另外还有不同数据扩 DSN的构造,Oracle数据库自己很多特殊的东西,都需要深入去学习理解,这篇文章就只是简单的描述了一些入门知识,算是对PDO一个简单的了解吧。

 

分类: 数据库 标签:

今天学的Linux命令

2012年5月8日 1 条评论
名称:cat
使用权限:所有使用者
使用方式:cat [-AbeEnstTuv] [--help] [--version] fileName
说明:把档案串连接后传到基本输出(萤幕或加 > fileName 到另一个档案)
参数:
-n 或 –number 由 1 开始对所有输出的行数编号
-b 或 –number-nonblank 和 -n 相似,只不过对于空白行不编号
-s 或 –squeeze-blank 当遇到有连续两行以上的空白行,就代换为一行的空白行
-v 或 –show-nonprinting
范例:
cat -n textfile1 > textfile2 把 textfile1 的档案内容加上行号后输入 textfile2 这个档案里
cat -b textfile1 textfile2 >> textfile3 把 textfile1 和 textfile2 的档案内容加上行号(空白行不加)之后将内容附加到 textfile3
名称:rm
使用权限:所有使用者
使用方式:rm [options] name…
说明:删除档案及目录。
参数:
-i 删除前逐一询问确认。
-f 即使原档案属性设为唯读,亦直接删除,无需逐一确认。
-r 将目录及以下之档案亦逐一删除。
范例:
删除所有C语言程式档;删除前逐一询问确认 :
rm -i *.c
将 Finished 子目录及子目录中所有档案删除 :
rm -r Finished

ps -ef | grep aaa 搜索包含aaa的进程,并显示

进入vi的命令
  vi filename :打开或新建文件,并将光标置于第一行首
  vi +n filename :打开文件,并将光标置于第n行首
  vi + filename :打开文件,并将光标置于最后一行首
  vi +/pattern filename:打开文件,并将光标置于第一个与pattern匹配的串处
  vi -r filename :在上次正用vi编辑时发生系统崩溃,恢复filename
  vi filename….filename :打开多个文件,依次进行编辑
  移动光标类命令[/b]
  h :光标左移一个字符
  l :光标右移一个字符
  space:光标右移一个字符
  Backspace:光标左移一个字符
  k或Ctrl+p:光标上移一行
  j或Ctrl+n :光标下移一行
  Enter :光标下移一行
  w或W :光标右移一个字至字首
  b或B :光标左移一个字至字首
  e或E :光标右移一个字至字尾
  ) :光标移至句尾
  ( :光标移至句首
  }:光标移至段落开头
  {:光标移至段落结尾
  nG:光标移至第n行首
  n+:光标下移n行
  n-:光标上移n行
  n$:光标移至第n行尾
  H :光标移至屏幕顶行
  M :光标移至屏幕中间行
  L :光标移至屏幕最后行
  0:(注意是数字零)光标移至当前行首
  $:光标移至当前行尾
  屏幕翻滚类命令
  Ctrl+u:向文件首翻半屏
  Ctrl+d:向文件尾翻半屏
  Ctrl+f:向文件尾翻一屏
  Ctrl+b;向文件首翻一屏
  nz:将第n行滚至屏幕顶部,不指定n时将当前行滚至屏幕顶部。
  插入文本类命令
  i :在光标前
  I :在当前行首
  a:光标后
  A:在当前行尾
  o:在当前行之下新开一行
  O:在当前行之上新开一行
  r:替换当前字符
  R:替换当前字符及其后的字符,直至按ESC键
  s:从当前光标位置处开始,以输入的文本替代指定数目的字符
  S:删除指定数目的行,并以所输入文本代替之
  ncw或nCW:修改指定数目的字
  nCC:修改指定数目的行
  删除命令
  ndw或ndW:删除光标处开始及其后的n-1个字
  do:删至行首
  d$:删至行尾
  ndd:删除当前行及其后n-1行
  x或X:删除一个字符,x删除光标后的,而X删除光标前的
  Ctrl+u:删除输入方式下所输入的文本
  搜索及替换命令
  /pattern:从光标开始处向文件尾搜索pattern
  ?pattern:从光标开始处向文件首搜索pattern
  n:在同一方向重复上一次搜索命令
  N:在反方向上重复上一次搜索命令
  :s/p1/p2/g:将当前行中所有p1均用p2替代
  :n1,n2s/p1/p2/g:将第n1至n2行中所有p1均用p2替代
  :g/p1/s//p2/g:将文件中所有p1均用p2替换
  选项设置
  all:列出所有选项设置情况
  term:设置终端类型
  ignorance:在搜索中忽略大小写
  list:显示制表位(Ctrl+I)和行尾标志($)
  number:显示行号
  report:显示由面向行的命令修改过的数目
  terse:显示简短的警告信息
  warn:在转到别的文件时若没保存当前文件则显示NO write信息
  nomagic:允许在搜索模式中,使用前面不带“\”的特殊字符
  nowrapscan:禁止vi在搜索到达文件两端时,又从另一端开始
  mesg:允许vi显示其他用户用write写到自己终端上的信息
  最后行方式命令
  :n1,n2 co n3:将n1行到n2行之间的内容拷贝到第n3行下
  :n1,n2 m n3:将n1行到n2行之间的内容移至到第n3行下
  :n1,n2 d :将n1行到n2行之间的内容删除
  :w :保存当前文件
  :e filename:打开文件filename进行编辑
  :x:保存当前文件并退出
  :q:退出vi
  :q!:不保存文件并退出vi
  :!command:执行shell命令command
  :n1,n2 w!command:将文件中n1行至n2行的内容作为command的输入并执行之,若不指定n1,n2,则表示将整个文件内容作为command的输入
  :r!command:将命令command的输出结果放到当前行
  寄存器操作
  ”?nyy:将当前行及其下n行的内容保存到寄存器?中,其中?为一个字母,n为一个数字
  ”?nyw:将当前行及其下n个字保存到寄存器?中,其中?为一个字母,n为一个数字
  ”?nyl:将当前行及其下n个字符保存到寄存器?中,其中?为一个字母,n为一个数字
  ”?p:取出寄存器?中的内容并将其放到光标位置处。这里?可以是一个字母,也可以是一个数字
  ndd:将当前行及其下共n行文本删除,并将所删内容放到1号删除寄存器中。
分类: 未分类 标签: