Linux常用命令

来源:互联网 发布:淘宝上的星巴克月饼券 编辑:程序博客网 时间:2024/05/23 02:02

常用命令:

 一、ls 只列出文件名 (相当于dir,dir也可以使用)

-A:列出所有文件,包含隐藏文件。

-l:列表形式,包含文件的绝大部分属性。

-R:递归显示。

--help:此命令的帮助。

 二、cd 改变目录

cd /:进入根目录

cd :回到自己的目录(用户不同则目录也不同,root为/root,xxt为/home/xxt

 cd..:回到上级目录

pwd:显示当前所在的目录

 三.less 文件名:查看文件内容。

 四.q 退出打开的文件。

 五.上传文件: rz 选择要传送的文件,确定。

 六.下载文件: sz 指定文件名,enter敲,即下载到了secureCRT/download目录下。

 七:删除文件: rm 删除文件 ,rmdir 删除空目录。

 

八.显示最近输入的20条命令:history 20

 

九.获得帮助命令 --help查看命令下详细参数:  如:rz--help   , sz --help  。

 

 

十.cd 进入某个文件夹的命令:

mkdir+文件夹名 创建某个文件夹的命令

sz+文件名 从服务器端向本机发送文件的命令

rz 从本机向服务器端传送文件的命令

ll 列出当前目录下的所有文件,包括每个文件的详细信息

dir 对当前文件夹

vi 打开当前文件

 十一.在编辑某个文件的时候:

a 切换到编辑模式

ctrl+c 退出编辑模式

dd 删除整行

:q 退出当前文件

:w 写入并保存当前文件

-f 强行xx的参数。。。

 

其它命令:

1.ps -ef //查看server的进程,以列表形式显示的server进程。

 ps 显示当前在系统运行的进程/usr/bin/ps [选项] -e 显示每个现在运行的进程 -f 生成一个完全的列表

 

实际操作:

--------------------------------------

1 SSH客户端连接到10.5.1.55系统(参见《启动远程客户端说明SecureCRT.doc》)

$ cd /home/bea2/user_projects/csdomain/bin

 2 查看weblogic92服务进程

$ ps -eaf | grep weblogic

     bea2 327926 331940   0 13:08:45 pts/4 0:00 grep weblogic

 webadmin 421908 368956   0  Sep 24      - 4:13/usr/java5_64/bin/java -Xms256m -Xmx512m -da -Dplatform.home=/home/weblogic/bea/weblogic92-Dwls.home=/home/weblogic/bea/weblogic92/server -Dwli.home=/home/weblogic/bea/weblogic92/integration-Dweblogic.management.discover=true -Dwlw.iterativeDev=false-Dwlw.testConsole=false -Dwlw.logErrorsToConsole=-Dweblogic.ext.dirs=/home/weblogic/bea/patch_weblogic923/profiles/default/sysext_manifest_classpath-Dweblogic.Name=AdminServer-Djava.security.policy=/home/weblogic/bea/weblogic92/server/lib/weblogic.policyweblogic.Server

 bea2491796 385044 17 00:12:50 pts/6 182:55 /usr/java5_64/bin/java -Xms6g -Xmx8g-javaagent:/home/bea2/user_projects/csdomain/Introscope/wily/Agent.jar-Dcom.wily.introscope.agentProfile=/home/bea2/user_projects/csdomain/Introscope/wily/IntroscopeAgent.profile-Dcom.wily.introscope.agent.agentName=AdminServer -da-Dplatform.home=/home/weblogic/bea/weblogic92-Dwls.home=/home/weblogic/bea/weblogic92/server-Dwli.home=/home/weblogic/bea/weblogic92/integration-Dweblogic.management.discover=true -Dwlw.iterativeDev= -Dwlw.testConsole=-Dwlw.logErrorsToConsole= -Dfile.encoding=GBK -Dibm.stream.nio=true-Dweblogic.ext.dirs=/home/weblogic/bea/patch_weblogic923/profiles/default/sysext_manifest_classpath-Dweblogic.Name=AdminServer -Djava.security.policy=/home/weblogic/bea/weblogic92/server/lib/weblogic.policyweblogic.Server

说明:根据以上提示查看登陆用户bea2启动的进程,注意标红的bea2为进程拥有着, 491796为进程号

3 执行如下命令杀掉进程

$ kill -9 491796(根据2操做查找到得系统进程号)

 说明:执行后再执行$ ps-eaf | grep weblogic命令将不会看到该进程号的weblogic进程

4 启动服务

$ ./quickRun.sh

 

-------------------------------------------------------------------

2.ant -buildfile CMS_MainTrunk.xml  //build 包

3.vi test.txt  //浏览文件内容

i {insert写输入}

esc  退出insert

 :wq!write 保存并退出vi模式 

 :q!  不保存退出vi模式

4.我一般习惯用ps –ef命令,这样看到以列表形式显示的server进程;用命令pstree来查看server的进程,这样看到以树的形式显示的server进程。

Pstree命令的优点在于可以立即找出某进程的父进程。您可能会需要使用 -p 选项显示每个进程的 PID,以及 -u 选项来显示启动该进程的用户名。

 一般来说,这一树结构比较长,您就需要这么执行 pstree –up | less 这将让您纵览整个进程树结构。

5.secureCRT中乱码解决:Options->SessionOptions->Appearance->font把default改成UTF-8,就可以显示中文字体了。

 

6.hostname:查hostname

 7.ifconfig 查询主机IP

 8.在S-CRT下用ctrl+c 和ctrl+v:

Options---Global Options---Edit defaultSettings进去后点Terminal---Emulation然后点Mapped Keys,点中低部的,use windows copy and paste key,点确认。

 

 

 

1.进入sql运行环境。

[test@test bin]$ ./psql -n dbname -Uusrname

 stay81=# select count(*) from table1;

 count

-------

 5986

 (1row)

 9.进入vi的命令:

vi filename :打开或新建文件,并将光标置于第一行首

vi +n filename :打开文件,并将光标置于第n行首

vi + filename :打开文件,并将光标置于最后一行首

vi +/pattern filename:打开文件,并将光标置于第一个与pattern匹配的串处

10.移动光标类命令:

}:光标移至段落开头

{:光标移至段落结尾

nG:光标移至第n行首

n+:光标下移n行

n-:光标上移n行

n$:光标移至第n行尾

H :光标移至屏幕顶行

M :光标移至屏幕中间行

L :光标移至屏幕最后行

0:(注意是数字零)光标移至当前行首

$:光标移至当前行尾

11.屏幕翻滚类命令:

Ctrl+u:向文件首翻半屏

Ctrl+d:向文件尾翻半屏

Ctrl+f:向文件尾翻一屏  //好像是 r

 Ctrl+b;向文件首翻一屏

 

12.搜索命令:

/pattern:从光标开始处向文件尾搜索pattern

 ?pattern:从光标开始处向文件首搜索pattern

 n:在同一方向重复上一次搜索命令

N:在反方向上重复上一次搜索命令

 

postgres使用:

2. 退出,使用结束后退出,不然连接一直被挂起。

stay81=# \q

 3.postgres 数据导出。

[postgres@test bin]$ ./pg_dump -U postgres-t testTable -d testDB > testTable.dump

或[postgres@test bin]$ ./pg_dump -U postgres -d testDB -t testTable -Fc -v > testTable.dump

 4.postgres 数据导入。

[postgres@test bin]$ ./psql -U postgres -dtestDB < testTable.dump

或[postgres@test bin]$ ./pg_restore -U postgres -d testDB <testTable.dump

 5.一台主机上将数据库目录转储到另一台主机上。

pg_dump -h host1 -p 5432 dbname | psql -hhost2 -p post1 dbname

或./pg_dump -U postgres -d testDB1 -t testTable | ./psql -U postgres-d testDB2

-U 为用户名 ,-d 为DB名,-t 为表名称,如果整个数据库导出,不需此项。

6.php执行。

[test@test bin]$ /usr/bin/php -q./batchstart.php

 

 

实战操作:

/home/absys6$ ls

 dvlp              dvlp_bak20090413  personal          tmp

 /home/absys6$ cd dvlp

 /home/absys6/dvlp$ ls

 /home/absys6/dvlp$ cd SV_POLICY

 /home/absys6/dvlp/SV_POLICY$ ls

 include src

 /home/absys6/dvlp/SV_POLICY$ cd src

 /home/absys6/dvlp/SV_POLICY/src$ ls

 /home/absys6/dvlp/SV_POLICY/src$ ls *pc    //对文件进行筛选

/home/absys6/dvlp/SV_POLICY/src$ grep VIP*pc //列出包含VIP的所有.pc的文件的代码的一部分。

/home/absys6/dvlp/SV_POLICY/src$ viPlyPrmCnt.pc  //查看整个文件。

 

 

 

 

SecureCRT常用命令(2011-04-21 07:43:43)转载▼标签: it 分类: 技术相关 

SecureCRT命令:

 

startup.sh     //启动tomcat,startup.sh做了映射的话,可以在任何目录下

shutdown.sh   //关tomcat

cd /home    //到home 目录

 

ll          //列出当前目录下的所有文件,包括每个文件的详细信息

 

ls         //只列出文件名

 

ps -ef     //查看server的进程,以列表形式显示的server进程。

 

ps   //显示当前在系统运行的进程 /usr/bin/ps [选项] -e 显示每个现在运行的进程 -f 生成一个完全的列表

 

ant -buildfile CMS_MainTrunk.xml  //build 包

 

 

 

过程:先Undeploy  ,再关tomcat,然后再build(ant),最后启动tomcat

 

 

 

tomcate root:   /usr/local/jakarta-tomcat-5.0.28

 

[root@localhost classes]# vi test.txt  //浏览文件内容

 

i    //{insert写输入}

esc  //退出insert

:wq! // write 保存并退出vi模式 

:q!  //不保存退出vi模式

 

pwd //显示当前工作目录

 

 

 

在 shell 提示下键入 history可以查看以前输入过的命令(对该服务器输入过的历史命令,并不一定都是自己曾输的)。

# history 20    (显示最后20条命令)

 

平时用secureCRT查看server的进程时,一般习惯用ps –ef命令,这样看到以列表形式显示的server进程。

 

偶然发现还有命令可以以进程树的形式显示server进程,也就是可以显示进程的派生关系,输入了这个命令pstree怎么是乱码啊,那就设置一下中文字体看看吧。

 

在secureCRT中:Options->SessionOptions->Appearance->font把default改成UTF-8就可以了:

再用命令pstree来查看server的进程,这样看到以树的形式显示的server进程。如下:

看看pstree的man手册怎么说的把:

功能说明:以树状图显示程序。

  语  法:pstree [-acGhlnpuUV][-H <程序识别码>][<程序识别码>/<用户名称>]

  补充说明:pstree指令用ASCII字符显示树状结构,清楚地表达程序间的相互关

系。如果不指定程序识别码或用户名称,则会把系统启动时的第一个程序视为基层,并

显示之后的所有程序。若指定用户名称,便会以隶属该用户的第一个程序当作基层,然

后显示该用户的所有程序。

  参  数:

  -a  显示每个程序的完整指令,包含路径,参数或是常驻服务的标示。

  -c  不使用精简标示法。

  -G  使用VT100终端机的列绘图字符。

  -h  列出树状图时,特别标明现在执行的程序。

  -H<程序识别码>  此参数的效果和指定"-h"参数类似,但特别标明指定的程序。

  -l  采用长列格式显示树状图。

  -n  用程序识别码排序。预设是以程序名称来排序。

  -p  显示程序识别码。

  -u  显示用户名称。

  -U  使用UTF-8列绘图字符。

  -V  显示版本信息。

Pstree命令的优点在于可以立即找出某进程的父进程:当用户想要终止整个进程系列而且其中存在了许许多多的下属分支进程,您只需终止最上层的进程即可。您可能会需要使用 -p 选项显示每个进程的 PID,以及 -u 选项来显示启动该进程的用户名。一般来说,这一树结构比较长,您就需要这么执行 pstree –up | less 这将让您纵览整个进程树结构。

 

hostname:查hostname

 

ifconfig 查询主机IP

 

在你是否曾经因为在S-CRT下不能用ctrl+c 和ctrl+v而烦恼?

Options-----Global Options---Edit defaultSettings进去后点Terminal----Emulation然后点Mapped Keys,点中低部的,use windows copy and paste key,点确认

 

1、当你对一个网络进行完一个操作后,忽然发现你忘了monitor session ,或者sh run 出来将近一万行命令,屏幕往回翻,又翻不了几页,这时,你可以修改一个参数,达到效果,具体如下:

Options-----Global Options---Edit defaultSettings进去后点Terminal----Emulation---下面的Scroll back后面的数字自己修改好了,比如我选了10000,你也可以选更大的,再点OK

 

将linux上文件传到PC机上

 

[root@test root]# sz /etc/rc.local

 

将PC机上文件传到linux上

[root@test root]#  rz

选择要传送的文件,确定。

 

sz 指定文件名,用tab,就下载到download(X/Y/Zmodem中设置路径)下了

 

pwd:显示当前所在的目录

 

附:postgres使用

 

// 进入sql运行环境

[test@test bin]$ ./psql -n dbname -Uusrname

stay81=# select count(*) from table1;

 count

-------

 5986

(1 row)

 

// 退出,使用结束后退出,不然连接一直被挂起

stay81=# \q

 

// postgres 数据导出

[postgres@test bin]$ ./pg_dump -U postgres-t testTable -d testDB > testTable.dump

// postgres 数据导入

[postgres@test bin]$ ./psql -U postgres -dtestDB < testTable.dump

 

// postgres 数据导出

[postgres@test bin]$ ./pg_dump -U postgres-d testDB -t testTable -F c -v > testTable.dump

// postgres 数据导入

[postgres@test bin]$ ./pg_restore -Upostgres -d testDB < testTable.dump

 

// 一台主机上将数据库目录转储到另一台主机上

pg_dump -h host1 -p 5432 dbname | psql -hhost2 -p post1 dbname

./pg_dump -U postgres -d testDB1 -ttestTable | ./psql -U postgres -d testDB2

 

-U 为用户名

 

-d 为DB名

 

-t 为表名称,如果整个数据库导出,不需此项

 

// php执行

[test@test bin]$ /usr/bin/php -q./batchstart.php

 

SecureCRT 常用命令

 

Posted on 2010 年 4 月 26 日 by yyq129

 

 

常用命令:

 一、ls 只列出文件名 (相当于dir,dir也可以使用)

 -A:列出所有文件,包含隐藏文件。

 -l:列表形式,包含文件的绝大部分属性。

 -R:递归显示。

 –help:此命令的帮助。

 

二、cd 改变目录

 cd/:进入根目录

 cd :回到自己的目录(用户不同则目录也不同,root为/root,xxt为/home/xxt

 cd..:回到上级目录

 pwd:显示当前所在的目录

 

三.less 文件名:查看文件内容。

 

四.q 退出打开的文件。

 

五.上传文件: rz 选择要传送的文件,确定。

 

六.下载文件: sz 指定文件名,enter敲,即下载到了secureCRT/download目录下。

 

七:删除文件: rm 删除文件,rmdir 删除空目录。

 

 八.显示 最近输入的20条命令:history20

 

 九.获得帮助命令 –help查看命令下详细参数:  如:rz –help   , sz –help  。

 

十.cd 进入某个文件夹的命令:

 mkdir+文件夹名 创建某个文件夹的命令

 sz+文件名 从服务器端向本机发送文件的命令

 rz 从本机向服务器端传送文件的命令

 ll 列出当前目录下的所有文件,包括每个文件的详细信息

 dir 对当前文件夹

 vi 打开当前文件

 

十一.在编辑某个文件的时候:

 a 切换到编辑模式

 ctrl+c 退出编辑模式

 dd 删除整行

 :q 退出当前文件

 :w 写入并保存当前文件

 -f 强行xx的参数。。。

 

其它命令:

 1.ps-ef  //查看server的进程,以列表形式显示的server进程。

  ps 显示当前在系统运行的进程/usr/bin/ps [选项] -e 显示每个现在运行的进程 -f 生成一个完全的列表

 

实际操作:

 ————————————–

 

1 SSH客户端连接到10.5.1.55系统(参见《启动远程客户端说明SecureCRT.doc》)

 

$ cd /home/bea2/user_projects/csdomain/bin

 

2 查看weblogic92服务进程

 

$ ps -eaf | grep weblogic

 

   bea2 327926 331940   0 13:08:45pts/4 0:00 grep weblogic

 

webadmin 421908 368956   0  Sep 24      - 4:13/usr/java5_64/bin/java -Xms256m -Xmx512m -da-Dplatform.home=/home/weblogic/bea/weblogic92 -Dwls.home=/home/weblogic/bea/weblogic92/server-Dwli.home=/home/weblogic/bea/weblogic92/integration -Dweblogic.management.discover=true-Dwlw.iterativeDev=false -Dwlw.testConsole=false -Dwlw.logErrorsToConsole=-Dweblogic.ext.dirs=/home/weblogic/bea/patch_weblogic923/profiles/default/sysext_manifest_classpath-Dweblogic.Name=AdminServer -Djava.security.policy=/home/weblogic/bea/weblogic92/server/lib/weblogic.policyweblogic.Server

 

bea2 491796 385044 17 00:12:50 pts/6 182:55/usr/java5_64/bin/java -Xms6g -Xmx8g-javaagent:/home/bea2/user_projects/csdomain/Introscope/wily/Agent.jar-Dcom.wily.introscope.agentProfile=/home/bea2/user_projects/csdomain/Introscope/wily/IntroscopeAgent.profile-Dcom.wily.introscope.agent.agentName=AdminServer -da-Dplatform.home=/home/weblogic/bea/weblogic92-Dwls.home=/home/weblogic/bea/weblogic92/server-Dwli.home=/home/weblogic/bea/weblogic92/integration-Dweblogic.management.discover=true -Dwlw.iterativeDev= -Dwlw.testConsole=-Dwlw.logErrorsToConsole= -Dfile.encoding=GBK -Dibm.stream.nio=true-Dweblogic.ext.dirs=/home/weblogic/bea/patch_weblogic923/profiles/default/sysext_manifest_classpath-Dweblogic.Name=AdminServer-Djava.security.policy=/home/weblogic/bea/weblogic92/server/lib/weblogic.policyweblogic.Server

 

说明:根据以上提示查看登陆用户bea2启动的进程,注意标红的bea2为进程拥有着, 491796为进程号

 

3 执行如下命令杀掉进程

 

$ kill -9 491796(根据2操做查找到得系统进程号)

 

说明:执行后再执行$ ps -eaf | grep weblogic命令将不会看到该进程号的weblogic进程

 

4 启动服务

 

$ ./quickRun.sh

 

——————————————————————-

 2.ant -buildfile CMS_MainTrunk.xml  //build 包

 

3.vi test.txt  //浏览文件内容

 i{insert写输入}

 esc  退出insert

 :wq!write 保存并退出vi模式 

 :q!  不保存退出vi模式

 

4.我一般习惯用ps –ef命令,这样看到以列表形式显示的server进程;用命令pstree来查看server的进程,这样看到以树的形式显示的server进程。

 Pstree命令的优点在于可以立即找出某进程的父进程。您可能会需要使用 -p 选项显示每个进程的 PID,以及 -u 选项来显示启动该进程的用户名。

 一般来说,这一树结构比较长,您就需要这么执行 pstree –up | less 这将让您纵览整个进程树结构。

 

5.secureCRT中乱码解决:Options->SessionOptions->Appearance->font把default改成UTF-8,就可以显示中文字体了。

 

 6.hostname:查hostname

 

7.ifconfig 查询主机IP

 

8.在S-CRT下用ctrl+c 和ctrl+v:

 Options—Global Options—Edit defaultSettings进去后点Terminal—Emulation然后点Mapped Keys,点中低部的,use windows copy and paste key,点确认。

 

9.进入vi的命令:

 vifilename :打开或新建文件,并将光标置于第一行首

 vi+n filename :打开文件,并将光标置于第n行首

 vi +filename :打开文件,并将光标置于最后一行首

 vi+/pattern filename:打开文件,并将光标置于第一个与pattern匹配的串处

 

10.移动光标类命令:

 }:光标移至段落开头

 {:光标移至段落结尾

 nG:光标移至第n行首

 n+:光标下移n行

 n-:光标上移n行

 n$:光标移至第n行尾

 H :光标移至屏幕顶行

 M :光标移至屏幕中间行

 L :光标移至屏幕最后行

 0:(注意是数字零)光标移至当前行首

 $:光标移至当前行尾

 

11.屏幕翻滚类命令:

 Ctrl+u:向文件首翻半屏

 Ctrl+d:向文件尾翻半屏

 Ctrl+f:向文件尾翻一屏  //好像是 r

 Ctrl+b;向文件首翻一屏

 

 12.搜索命令:

 /pattern:从光标开始处向文件尾搜索pattern

 ?pattern:从光标开始处向文件首搜索pattern

 n:在同一方向重复上一次搜索命令

 N:在反方向上重复上一次搜索命令

 

postgres使用:

 1.进入sql运行环境。

 [test@test bin]$ ./psql -n dbname -U usrname

 stay81=# select count(*) from table1;

 count

 ——-

  5986

 (1row)

 

2. 退出,使用结束后退出,不然连接一直被挂起。

 stay81=# \q

 

3.postgres 数据导出。

 [postgres@test bin]$ ./pg_dump -U postgres -ttestTable -d testDB > testTable.dump

 或[postgres@testbin]$ ./pg_dump -U postgres -d testDB -t testTable -F c -v > testTable.dump

 

4. postgres 数据导入。

 [postgres@test bin]$ ./psql -U postgres -dtestDB < testTable.dump

 或[postgres@testbin]$ ./pg_restore -U postgres -d testDB < testTable.dump

 

5.一台主机上将数据库目录转储到另一台主机上。

 pg_dump -h host1 -p 5432 dbname | psql -hhost2 -p post1 dbname

 或./pg_dump -Upostgres -d testDB1 -t testTable | ./psql -U postgres -d testDB2

 -U 为用户名 ,-d 为DB名,-t 为表名称,如果整个数据库导出,不需此项。

 

6.php执行。

 [test@test bin]$ /usr/bin/php -q./batchstart.php

 实战操作:

 /home/absys6$ ls

 dvlp              dvlp_bak20090413  personal          tmp

 /home/absys6$ cd dvlp

 /home/absys6/dvlp$ ls

 /home/absys6/dvlp$ cd SV_POLICY

 /home/absys6/dvlp/SV_POLICY$ ls

 include src

 /home/absys6/dvlp/SV_POLICY$ cd src

 /home/absys6/dvlp/SV_POLICY/src$ ls

 /home/absys6/dvlp/SV_POLICY/src$ ls *pc    //对文件进行筛选

 /home/absys6/dvlp/SV_POLICY/src$ grep VIP *pc//列出包含VIP的所有.pc的文件的代码的一部分。

 /home/absys6/dvlp/SV_POLICY/src$ viPlyPrmCnt.pc  //查看整个文件。

 

SecureCRT配置路由器

 

主机名:主机IP

 用户名:root

 密码:密码

 

*************显示当前非法网址*************

 moreyellow.list        回车

 按空格键下翻

 *************插入新记录*************

 viyellow.list          回车

 按i键,提示insert,     回车

 即可输入或删除记录

 *************保存操作*************

 按ESC,insert消失。

 此时输入:wq!           回车

 

*************让设置生效*************

 

service squid restart   回车

 *************如果要修改密码*************

 passwd root             回车

 输入密码

 再次确认

 *************如果要删除某条记录*************

 vi/etc/squid/yellow.list       编辑yellow.list

 /filename                       将光标定位到某记录

 dd                              删除该行记录

 *************重建yellow.list*************

 rm-rf /etc/squid/yellow.list   删除yellow.list

 touch /etc/squid/yellow.list    新建yellow.list

 vi/etc/squid/yellow.list       再次编辑yellow.list

 

附:vi命令一览表

 

    文本编辑器是所有计算机系统中最常用的一种工具。UNIX下的编辑器有ex,sed和vi等,其中,使用最为广泛的是vi,而vi命令繁多,以下稍做总结,以资共享。

 

进入vi的命令

 vifilename :打开或新建文件,并将光标置于第一行首

 vi+n filename :打开文件,并将光标置于第n行首

 vi +filename :打开文件,并将光标置于最后一行首

 vi+/pattern filename:打开文件,并将光标置于第一个与pattern匹配的串处

 vi-r filename :在上次正用vi编辑时发生系统崩溃,恢复filename

 vifilename….filename :打开多个文件,依次进行编辑

 

移动光标类命令

 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,n2w!command:将文件中n1行至n2行的内容作为command的输入并执行之,若不指定n1,n2,则表示将整个文件内容作为command的输入

 :r!command:将命令command的输出结果放到当前行

 

寄存器操作

 “?nyy:将当前行及其下n行的内容保存到寄存器?中,其中?为一个字母,n为一个数字

 “?nyw:将当前行及其下n个字保存到寄存器?中,其中?为一个字母,n为一个数字

 “?nyl:将当前行及其下n个字符保存到寄存器?中,其中?为一个字母,n为一个数字

 “?p:取出寄存器?中的内容并将其放到光标位置处。这里?可以是一个字母,也可以是一个数字

 ndd:将当前行及其下共n行文本删除,并将所删内容放到1号删除寄存器中

 

0 0