|
UNIX基本操作培训材料
获得帮助:UNIX系统为每一个操作、系统调用和系统函数都定义了一个完整的说明文文件,在命令(终端)模式下可通过man命令来显示该说明。例如:要看命令 ls的说明可用 $ man ls 其中$为系统给出的一般用户的命令行提示符。 1、文件类型 (1).文本文件 (2).二进制文件:存储程序,图形,图象,声音,数据的文件。 (3).管道文件:进程间传送信息。 (4).设备文件:特殊文件,也是UNIX的特色,它是使用和管理各种硬件设备的文件,如光盘,软盘等。 (5).目录文件:组织管理文件的文件,它只储存有关文件名列表以及其他有关文件的信息。
2、目录: 常用目录含义: /bin 组织二进制文件。 /dev 组织外围设备。 /etc 组织各种用于系统管理的程序和数据。 /include 组织和C语言开发有关的头文件。 /lib 组织应用开发中的子程序库和开发工具。 /usr 组织与用户有关的文件。 /tmp 临时文件。
有关目录常用命令: mkdir 建立目录 cd / 改变路径,用法同DOS基本相同,区别在于DOS用"\",而 UNIX用"/",且CD与/之间一定要有空格. mv 将文件移到另一目录下。 pwd 显示当前所处绝对路径。 rmdir 删除空目录。
3、文件: 当我们列文件目录时,会看到 drwxrwxr-x 1 test dba 96 Nov 14 23:04 bin -r--r--r-- 1 test dba 16127 Oct 12 1999 rote 这里列的是两个文件,他们的文件名就是最右边的字符串,他们分别是bin 和 rote。我们以第一个文件bin 为例来讲一下各个字母的含义。左数第一个字母表示这个文件的类型."d"表示为目录文件。"l"表示链接文件。"b"表示块设备."c"表示字符设备。 "p"表示管道文件。可以看出,bin 是一个目录文件。 然后就是后面的rwxrwxr-x ,它们表示这个文件的访问权限,RWX分别表示读,写,执行。头三个字母RWX表示文件所有者拥有读写执行的权限,中间三个字母表示与所有者同组用户有读写执行权限,最后三个字母表示系统中其他用户有读,和执行权限,却没有写权限。 接下来是数字1,表示该文件的链接数。 然后是test 表示用户名。 然后是dba 表示用户所在组名。 然后是数字96 表示文件大小。 然后是文件修改日期和文件名。
4、UNIX系统的关闭 shutdown –g0 –y 表示立即关机,不做等待。-g后面的数字表示等待时间。这时,系统中所有进程将被终止,同时系统将用内存缓冲区中的内容对磁盘有关内容更新,以保持系统同步。而突然断电则破坏这一过程,所以不正常关机极易破坏数据,导致系统崩溃。 在关闭作为主机的UNIX系统时,应在-g后跟一个非0的数字,表示系统关闭前的等待时间,一般为分钟数,对终端用户,系统将提示,以便用户保存现有工作,准备退出系统。
5、登录和退出
(1)登录步骤 login : _______ => 输入 username password : _______ => 输入密码
(2)退出步骤 logout 或 exit 或
(3)更改帐号密码 passwd => 执行後将会出现下列信息 Changing NIS password for user on ice. Old password: ______ => 输入旧密码 New password: ______ => 输入新密码(最好6-8字,英文字母与数字混合) Retype new password: ______ => 再输入一次密码
(4)远程登录 执行格式:rlogin hostname [-1 username] Example: $ rlogin doc $ remote login 进入主机 doc 中。 $ rlogin doc -l user 使用 user 帐号进入主机 doc 中。
执行格式:telnet hostname 或 telnet IP address Example: $ telnet doc or $telnet 140.109.20.251
6、文件及目录操作
(1)列出文件或目录下的文件 执行格式: ls [-atFlgR] [name] ( name 可为文件名或目录名称。)
Example : $ ls 列出目前目录下的文件名。 $ ls -a 列出包含以.起始的隐藏文件所有文件名。 $ ls -t 依照文件最後修改时间的顺序,依序列出文件名。 $ ls -F 列出目前目录下的文件名及其类型。"/" 结尾表示为目录名称, $ ls -l 列出目录下所有文件的许可权、拥有者、文件大小、修改时间及名称。 $ ls -lg 同上,并显示出文件的拥有者用户组名称。 $ ls -R 显示出目录下,以及其所有子目录的文件名。( recursive listing )
(2)目录缩写: ~ 使用者 login 时的 working directory ( 起始目录 ) ~username 指定某位 user 的 working directory ( 起始目录 ) . 目前的工作目录 ( current working directory ) .. 目前目录的上一层目录 ( parent of working directory)
(3)改变工作目录位置 执行格式:cd [name] :name 可为目录名称、路径或目录缩写。 Example: $ cd 改变目录位置,至使用者 login 时的 working directory (起始目录)。 $ cd dir1 改变目录位置,至 dir1 的目录位置下。 $ cd ~user 改变目录位置,至使用者的 working directory (起始目录)。 $ cd .. 改变目录位置,至目前目录的上层( 即 parent of working directory) $ cd ../user 改变目录位置,至相对路径 user 的目录位置下。 $ cd / 改变目录位置,至绝对路径( Full path ) 的根目录位置下。
(4)复制文件 执行格式: cp [-r] source destination
Example: $ cp file1 file2 将文件 file1 复制成 file2 $ cp file1 dir1 将文件 file1 复制到目录 dir1 下,文件名仍为 file1。 $ cp /tmp/file1 . 将目录 /tmp 下的文件 file1 复制到现行目录下,文件名仍为 file1。 $ cp /tmp/file1 file2 将目录 /tmp 下的文件 file1 复制到现行目录下,文件名为 file2□ $ cp -r dir1 dir2 (recursive copy) 复制整个目录。 若目录 dir2 不存在,则将目录 dir1,及其所有文件和子目录,复制 到目录 dir2 下,新目录名称为 dir1。若目录 dir2 不存在,则将 dir1,及其所有文件和子目录,复制为目录 dir2。
(5)搬移或更改文件、目录名称 执行格式: mv source destination Example: $ mv file1 file2 将文件 file1,更改文件名为 file2。 $ mv file1 dir1 将文件 file1,移到目录 dir1 下,文件名仍为 file1。 $ mv dir1 dir2 若目录 dir2 不存在,则将目录 dir1,及其所有文件和子目录,移 到目录 dir2 下,新目录名称为 dir1。若目录 dir2 不存在,则将 dir1,及其所有文件和子目录,更改为目录 dir2。
(6)建立新目录 执行格式: mkdir directory-name Exmaple : $ mkdir dir1 建立一新目录 dir1。
(7)删除目录 执行格式: rmdir directory-name 或 rm directory-name Example : $ rmdir dir1 删除目录 dir1,但 dir1 下必须没有文件存在,否则无法删除。 $ rm -r dir1 删除目录 dir1,及其下所有文件及子目录。应谨慎使用此命令。
(8)删除文件 执行格式: rm filename (filename 可为文件名,或文件名缩写符号。) Example : $ rm file1 删除文件名为 file1 的文件。 $ rm file? 删除文件名中有五个字符,前四个字符为file 的所有文件。 $ rm f* 删除文件名中,以 f 为字首的所有文件。
(9)文件名的缩写符号 ? 代表文件名称中的单一字符。 * 代表文件名称中的一字符串。
(10)列出当前所在的目录位置 执行格式: pwd
(11)查看文件内容 执行格式: cat filename Example : $ cat file1 以连续显示方式,查看文件名 file1 的内容。
执行格式: more filename 或 cat filename | more Example : $ more file1 以分页方式,查看文件名 file1 的内容。 $ cat file1 | more 同上。
(12)查看目录所占磁盘容量 执行格式: du [-s] directory Example : $ du dir1 显示目录 dir1 的总容量及其次目录的容量(以 k byte 为容量)。 $ du -s dir1 显示目录 dir1 的总容量。
(13) 查看磁盘使用情况 执行格式: df 列出的磁盘(逻辑盘)空间以段(一般为512字节)为单位 Example : $ df 列出使用空间数和文件数。 $ df -v 列出各磁盘的原有、占用和可用空间等信息。 $ df –k 列出的磁盘空间以k字节为单位。
7、文件传输 (1)拷贝文件或目录至远端主机 执行格式: rcp [-r] source hostname:destination ( source 可为文件名、目录名或路径,hostname 主机名,destination 为路径名称. Example : $ rcp file1 doc:/home/user 将文件 file1,拷贝到主机 doc 路径 /home/user 目录下。 $ rcp -r dir1 doc:/home/user 将目录 dir1,拷贝到主机 doc 路径/home/user 目录下。
(2)从远端主机,拷贝文件或目录 执行格式: rcp [-r] hostname:source destination ( hostname 为主机名,source 为路径名,destination 可为文件名、目录名或路径 )。 Example : $ rcp doc:/home/user/file1 file2 将主机 doc 中,位於 /home/user 目录下的目录 dir1,拷贝到目前主机的目录下, 目录名称仍为 dir1。 $ rcp -r doc:/home/user/dir1 . 将主机 doc 中,位於 /home/user 目录下的目录 dir1,拷贝到目前主机的目录下, 目录名称仍为 dir1。
(3)本地主机与远端主机之间的文件传输 ( 必须拥有远端主机的帐号及密码,才可进行传输工作 ) 执行格式: ftp hostname or ftp ip_address Example : ftp doc 与远端主机 doc ,进行文件传输 Name (doc:user-name) : 输入帐号 Password (doc:user-name): 输入密码
ftp> help 列出 ftp 文件传输,可使用的任何命令。 ftp> !ls 列出本地主机,目前目录下的所有文件名。 ftp> !pwd 列出本地主机,目前所在的工作目录位置。 ftp> ls 列出远端主机目前目录下的所有文件名。 ftp> dir 列出远端主机目前目录下的所有文件名(略同於 UNIX 的 ls -l 指令). ftp> dir . |more 同上,但每页会暂停(可能不适用 Unix 以外的 ftp)。 ftp> pwd 列出远端主机目前所在的目录位置。 ftp> cd dir1 更改远端主机的工作目录位置至 dir1 的下。 ftp> get file1 将远端主机的文件 file1 ,拷贝到本地主机中。 ftp> put file2 将本地主机的文件 file2 ,拷贝到远端主机中。 ftp> mget *.c 将远端主机中,副文件名为 c 的所有文件,拷贝到本地主机中。 ftp> mput *.txt 将本地主机中,副文件名为 txt 的所有文件,拷贝远端主机中。 ftp> prompt 切换交互式指令(使用 mput/mget 时不用每个文件皆询问yes/no)。 ftp> quit 结束 ftp 工作。 ftp> bye 结束 ftp 工作。 注: 从PC与主机间的文件传输也可通过在 PC端的 FTP指令进行文件传输,指令用法与上所述大致相同。
8、文件/目录属性 (1)改变文件或目录的读、写、执行的权限 执行格式:chmod [-R] mode name ( name 可为文件名或目录名;mode可为 3 个 8 进制的数字,或利用ls -l 命令,列出文件或目录的读、写、执行权限的文字缩写。) mode : rwx rwx rwx r:read w:write x:execute user group other 缩写 : (u) (g) (o) Example : $ chmod 755 dir1(755=111 101 101=rwx r-x r-x) 将目录dir1,设定成任何使用者,皆有读取及执行的权利,但只有拥有者可做修改。 $ chmod 700 file1 将文件file1,设定只有拥有者可以读、写和执行。 $ chmod o+x file2 将文件file2,增加拥有者可以执行的权利。 $ chmod g+x file3 将文件file3,增加用户组使用者可执行的权利。 $ chmod o-r file4 将文件file4,除去其它使用者可读取的权利。
(2)改变文件或目录的所有权 执行格式:chown [-R] username name ( name 可为文件名或目录名。) Example : $ chown user file1 将文件 file1 的所有权,改为使用者 user 所有。 $ chown -R user dir1 将目录 dir1,及其下所有文件和子目录的所有权,改为使用者 user 所有。 必须对文件/目录有读写权限的用户才能改变文件/目录的所有权。
(3)检查自己所属的用户组名称 执行格式:groups
(4)改变文件或目录所属的用户组 执行格式:chgrp [-R] groupname name ( name 可为文件名或目录名 ) Example : $ chgrp vlsi file1 将文件 file1 的用户组,改为 vlsi 用户组。 $ chgrp -R image dir1 将目录dir1,及其下所有文件和子目录,改为 image 用户组。 必须对文件/目录有读写权限的用户才能改变文件/目录的用户组。
(5)改变文件或目录的最後修改时间 执行格式:touch name ( name 可为文件或目录名称。)
9、文件的连结(类似于WINDOWS中的快捷方式)
同一文件,可拥有一个以上的名称,可将文件做数个连结。 执行格式:ln oldname newname ( Hard link ) Example : $ ln file1 file2 将名称 file2,连结至文件 file1。
执行格式:ln -s oldname newname ( Symblick link ) Example : $ ln -s file3 file4 将名称 file4,连结至文件file3。
10、文件/目录的查找和比较 (1)文件的字符串找寻 执行格式:grep string file Example : $ grep abc file1 寻找文件file1中,列出字符串 abc 所在的整行文字内容。
(2)找寻文件或命令的路径 执行格式:whereis command ( 显示命令的路径。) 执行格式:which command ( 显示命令的路径,及使用者所定义的别名。) 执行格式:whatis command ( 显示命令功能的摘要。) 执行格式:find search_path -name str -print ( 搜寻指定路径search_path下,含字符串str的文件或目录的路径 。) Example : $ find / -name abc -print 自根目录向下,寻含字符串abc的文件或目录的路径。.
(3)比较文件或目录的内容 执行格式:diff [-r] name1 name2 ( name1 name2 可同时为文件名,或目录名称。) Example : $ diff file1 file2 比较文件 file1 与 file2 内,各行的不同处。 $ diff -r dir1 dir2 比较目录 dir1 与 dir2 内,各文件的不同处。
11、任务的控制 UNIX 可在前台及后台同时处理多个进程。 一般使用者执行命令时,皆是在前台交互式地执行进程,亦可将进程 置於后台中,以非交互式来执行进程。
(1)查看系统的进程 执行格式:ps [-aux] Example: $ ps 或 ps -x (查看系统中,属於自己的进程。) $ ps -au (查看系统中,所有使用者的进程。) $ ps -aux (查看系统中,包含系统内部,及所有使用者的进程。)
(2)结束或终止进程 执行格式:kill [-9] PID ( PID 为利用 ps 命令所查出的进程 ID。) Example: $ kill 456 或 kill -9 456 终止进程 ID 为 456 的进程。
(3)在后台执行进程 的方式 执行格式:command & (於 command 後面加入一 "&" 符号即可。) Example: $ cc file1.c & 将编译 file1.c 文件的工作,置於后台执行。
执行格式:按下 "Control Z" 键,暂停正在执行的进程。键入 "bg" 命令, 命令,将所暂停的进程,置入后台中继续执行。 Example: $ cc file2.c ^Z Stopped $ bg
(4)查看正在后台中执行的进程 执行格式:jobs
(5)结束或终止在后台中的进程 执行格式:kill $n (n 为利用 "jobs" 命令,所查看出的后台任务编号) Example: $ kill % 终止在后台中的第一个 任务。 $ kill %2 终止在后台中的第二个 任务。
11、shell 变量
(1)查看shell变量的设定值 执行格式:set 查看所有shell变量的设定值。 Example:
$ set
执行格式:echo $变量名 显示指定的shell变量的设定值。 $ echo $INCLUDE /usr/test/include
(2)设定shell变量 执行格式:var = value export var Example: $ term=vt100 $ export term 设定shell变量 "term" 为 VT100 终端机的型式。
(3)删除shell变量 执行格式:unset var Example: $ unset INCLUDE 删除shell变量 "PRINTER" 的设定值。
12、environment 变量 (1)查看环境变量的设定值 执行格式:setenv 查看所有环境变量的设定值。 Example: $ setenv
执行格式:echo $NAME 显示指定的环境变量 "NAME" 的设定值。 Example: $echo $PRINTER 显示环境变量 "PRINTER" 打印机名称的设定值。
(2)设定环境变量 执行格式:setenv NAME word Example: $ setenv PRINTER sp1 设定环境变量 "PRINTER" 打印机名称为 sp1。
(3)删除环境变量 执行格式:unsetenv NAME Example: $ unsetenv PRINTER 删除环境变量 "PRINTER" 打印机名称的设定值。
13、别名 (1)查看所定义的命令的别名 执行格式: alias 查看自己目前定义的所有命令,及所对应的别名名称。 执行格式: alias name 查看指定的别名name所定义的命令。 Example: $ alias dir (查看别名 dir 所定义的命令) ls -atl
(2)定义命令的别名 ================== 执行格式: alias name 'command line' Example: $ alias dir 'ls -l' 将命令 "ls - l" 定义别名为 dir。
(3)删除所定义的别名 ==================== 执行格式: unalias name Example: $ unalias dir (删除别名为 dir 的定义。) $ unalias * (删除所有别名的设定。)
14、命令历史 (1)设定命令记录表的长度 执行格式: set history = n Example: $ set history = 40 设定命令记录表的长度为 40 (可记载执行过的前面 40 个命令)。
(2)查看命令记录表的内容 执行格式: history Example: $ history
(3)使用命令记录表 执行格式: !! Example: $ !! (重覆执行前一个命令)
执行格式: !n ( n 为命令记录表的命令编号。) Example: $ !5 ( 执行命令记录表中第五个命令。)
执行格式: !string ( 重覆前面执行过以 string 为起始字符的命令。) Example: $ !cat ( 重覆前面执行过,以 cat 为起始字符的命令。)
(4)显示前一个命令的内容 执行格式: !!:p
.更改前一命令的内容并执行 ============================ 执行格式: ^oldstring ^newstring 将前一命令中 oldstring 的部份,改成 newstring,并执行的。 Example: $ find . -name file1.c -print ^file1.c^core $ find . -name core -print
注:文件 core 为执行程式或命令发生错误时,系统所产生的文件。作为调试(debug)的参考,因其所占空间极大,通常将的删除。
15、文件的压缩 为了避免不常用的文件或文件,占用太大的磁盘空间,请使用者将的压缩。欲使用压缩过的文件或文件前,将其解压,即可还原成原来的文件型式。凡是经过压缩处理的文件,会在文件名後面附加 " .Z " 的字符,表示此为一压缩文件。 (1)压缩文件 执行格式:compress filename 压缩文件 执行格式:compressdir directory-name 压缩目录
(2)解压缩还原文件 执行格式:uncompress filename解压文件 执行格式:uncompressdir directory-name解压目录
管道的使用 ================ 执行格式:command1 | command2 将 command1 执行结果,送到 command2 做为 command2 的输入。 Example: $ ls -Rl | more 以分页方式,列出目前目录下所有文件,及子目录的名称。 $ cat file1 | more 以分页方式,列出文件 file1 的内容。 $ ps –ef | grep ora 列出正在执行的包含字符串ora的进程信息。
16、输入输出控制
(1)标准输入的控制 执行格式:command-line < file 将 file 做为 command-line 的输入。 Example: $mail -s "mail test" user@sina.com < file1 将文件 file1 当做信件的内容,Subject 名称为 mail test,送给收信人。
(2)标准输出的控制 执行格式:command > filename 将 command 的执行结果,送至指定的 filename 中。 Example: $ ls -l > list 将执行 "ls -l" 命令的结果,写入文件 list 中。 执行格式:command >! filename 同上,若 filename 的文件已经存在,则强迫 overwrite。 Example: $ ls -lg >! list 将执行 "ls - lg" 命令的结果,强迫写入文件 list 中。 执行格式:command >& filename 将 command 执行时,萤幕上所产生的任何讯息,写入指定的 filename 中。 Example: $ cc file1.c >& error 将编译 file1.c 文件时,所产生的任何讯息,写入文件 error 中。 执行格式:command >> filename 将 command 执行结果,附加(append)到指定的 filename 中。 Example: $ ls - lag >> list 将执行 "ls - lag" 命令的结果,附加(append)到文件 list 中。 执行格式:command >>& filename 将 command 执行时,萤幕上所产生的任何讯息,附加於指定的 filename中。 Example: $ cc file2.c >>& error 将编译 file2.c 文件时,萤幕所产生的任何讯息,附加於文件 error 中。
17、系统用户相关操作 (1)查看系统用户 执行格式: who 或 finger 执行格式: w 执行格式: finger username or finger username@domainname
(2)改变帐号,进入其他使用者的帐号,拥有其使用权利。 执行格式: su Example: $ su user 进入使用者 user 的帐号 passwrod: 输入使用者 user 的密码,不执行初始化文件。 $ su - user 进入使用者 user 的帐号 passwrod: 输入使用者 user 的密码,执行初始化文件。
(3)查看当前用户名: 执行格式: who am i 查看 login 时,自己的 username。 执行格式: whoami 查看目前的 username。若已执行过 "su"命令(switch user), 则显示出此 user 的 username。
(4)查看目前系统上所有主机的使用者: 执行格式: rusers => 结束
与某主机上的终端用户交谈: 执行格式: talk username@hostname 或 talk username@ip_address Example: 1. 可先利用 rusers 指令查看网路上的使用者 2. 假设自己的帐号是 u84987 ,在主机 indian 上使用,现在想要与 doc 上的 u84123 交互。 $talk u84123@doc ==> 此时萤幕上将会出现等待画面 在对方(u84123)萤幕上将会出现下列讯息 Message from Talk_Daemon@Local_host_name at xx:xx talk: connection requested by u84987@indian talk: respond with: talk u84987@indian
此时对方(u84123) 必须执行 talk u84987@indian 即可互相交互。 最後可按结束。
18、文件编辑器 vi 的使用方法简介 vi是在UNIX系统上被广泛使用的中英文编辑软件。对初学者而言,常因其特殊的使用方法,而不得其门而入;对已经在使用 vi 的使用者来说,也常见因对 vi 的不熟悉或不够了解,而无法发挥出 vi 强大的编辑能力,以下将介绍 vi 的使用方法简介。
操作列表: 进入 vi 离开 vi 输入模式 如何进入输入模式 如何离开输入模式 指令模式 游标的移动 屏幕的移动 删除、复制及修改指令介绍(delete、change、yank) 删除与修改(delete、replace) 搬移与复制(delete/put、yank/put) 指令重覆 取消前一动作(undo) 字符串搜寻 文件的连接与分行 环境的设定 ex 指令 其它方面 中文编辑 恢复编辑时被中断的文件 编辑多个文件
vi 是 visual editor 的缩写,是 UNIX 所提供的编辑器的一。它提供使用者一个 全屏幕的编辑环境。
..进入vi ======= 直接执行 vi编辑程式即可: $vi test 此刻萤幕上会出现 vi 的编辑窗口,同时 vi 会将文件复制一份至内存中的缓冲区 (buffer) 。 vi会保留在磁盘中的文件不变,而先对缓冲区的文件案作编辑,编辑完成後,使用者可决定是否要取代原有的文件。
..离开vi ======= 若在输入模式下,则先利用《ESC》进入指令模式,而後即可选用下列指令 离开vi。 :q! 离开vi,并放弃刚在缓冲区内编辑的内容。 :wq 将缓冲区内的文件写入磁盘中,并离开vi。 :ZZ 同wq。 :x 同wq。 :w 将缓冲区内的文件写入磁盘中,但并不离开vi。 :q 离开vi,若文件被修改过,则会被要求确认是否放弃修改的内容。 此指令可与:w 配合使用。
..vi 的操作模式 ============== vi 提供两种操作模式:输入模式(insert mode)和指令模式(command mode) 。当使用者进入 vi 後,即处在指令模式下,此刻键入的任何字符皆被视为 指令。在此模式下可进行删除、修改等动作。若要输入文件,则需进入输入 模式。
..输入模式 ========= 如何进入输入模式 a (append) 由游标的後加入文件。 A 由该行的末加入文件。 i (insert) 由游标的前加入文件。 I 由该行的首加入文件。 o (open) 新增一行於该行的下供输入文件的用。 O 新增一行於该行的上供输入文件的用。
如何离开输入模式 《ESC》 结束输入模式。
..指令模式 ========= 游标的移动 h 向左移一个字符。 j 向上移一个字符。 k 向下移一个字符。 l 向右移一个字符。 0 移至该行的首 $ 移至该行的末。 ^ 移至该行的第一个字符处。 H 移至窗口的第一列。 M 移至窗口的中间那列。 L 移至窗口的最後一列。 G 移至该文件的最後一列。 + 移至下一列的第一个字符处。 - 移至上一列的第一个字符处。 ( 移至该句的首。 (注一) ) 移至该句的末。 { 移至该段落的首。 (注二) } 移至该段落的末。 nG 移至该文件的第 n 列。 n+ 移至游标所在位置的後的第 n 列。 n- 移至游标所在位置的前的第 n 列。 会显示该行的行号、文件名称、文件中最末行的行号、游标 所在行号占总行号的百分比。
注一:句子(sentence)在vi中是指以『!』、『.』或『?』结束的一串字。 注二:段落(paragraph)在vi中是指以空白行隔开的文字。
..窗口的移动 =========== 窗口往下卷一页。 窗口往上卷一页。 窗口往下卷半页。 窗口往上卷半页。 窗口往下卷一行。 窗口往上卷一行。
..删除、复制及修改指令介绍 (此单元较少使用) ========================= d(delete)、c(change)和y(yank)这一类的指令在 vi 中的指令格式为: Operator + Scope = command (运算子) (范围) 运算子: d 删除指令。删除文件,但会将删除文件复制到内存缓冲区。 y 将文件(字组、行列、句子或段落)复制到缓冲区。 p 放置(put)指令,与 d 和 y 配和使用。可将最後delete或yank的资 料放置於游标所在位置的行列下。 c 修改(change)指令,类似delete与insert的组和。删除一个字组、句 子等的文件,并插入新键文件。
范围: e 由游标所在位置至该字符串的最後一个字符。 w 由游标所在位置至下一个字符串的第一个字符。 b 由游标所在位置至前一个字符串的第一个字符。 $ 由游标所在位置至该行的最後一个字符。 0 由游标所在位置至该行的第一个字符。 ) 由游标所在位置至下一个句子的第一个字符。 ( 由游标所在位置至该句子的第一个字符。 { 由游标所在位置至该段落的最後一个字符。 } 由游标所在位置至该段落的第一个字符。
整行动作 dd 删除整行。 D 以行为单位,删除游标後的所有字符。 cc 修改整行的内容。 yy yank整行,使游标所在该行复制到内存缓冲区。
..删除与修改 =========== x 删除游标所在该字符。 X 删除游标所在的前一字符。 dd 删除游标所在该行。 r 用接於此指令的後的字符取代(replace)游标所在字符。 如: ra 将游标所在字符以 a 取代的。 R 进入取代状态,直到《ESC》为止。 s 删除游标所在的字符,并进入输入模式直到《ESC》。 S 删除游标所在的该行文件,并进入输入模式直到《ESC》。
..搬移与复制 ========== 利用 delete 及 put 指令可完成文件搬移的目的。 利用 yank 及 put 指令可完成文件复制的目的。 yank 和 delete 可将指定的文件复制到内存缓冲区,而藉由 put 指令 可将缓冲区内的文件复制到萤幕上。 例: 搬移一行 .在该行执行 dd .游标移至目的地 .执行 p 复制一行 .在该行执行 yy .游标移至目的地 .执行 p
..指令重复 ========= 在指令模式中,可在指令前面加入一数字 n,则此指令动作会重复执行 n 次。 例: 删除10行 .10dd 复制10行 .10yy .游标移至目的地 .p 指标往下移10行 .10j
..取消前一动作(Undo) =================== 即复原执行上一指令前的内容。
u 恢复最後一个指令的前的结果。 U 恢复游标该行的所有改变。
..搜寻 ===== 在vi中可搜寻某一字符串,使游标移至该处。
/字符串 往游标的後寻找该字符串。 ?字符串 往游标的前寻找该字符串。 n 往下继续寻找下一个相同的字符串。 N 往上继续寻找下一个相同的字符串。
..文件的连接 =========== J 句子的连接。将游标所在的下一行连接至游标该行的後面。
若某行文件太长亦可将其分成两行,只要将游标移至分开点,进入输入模式 (可利用 a、i等指令)再按《Enter》即可。
..环境的设定 =========== :set nu 设定文件的行号。 :set nonu 取消行号设定。 :set ai 自动内缩。 :set noai 取消自动内缩。
自动内缩(automatic indentation) 在编辑文件或程式时,有时会遇到需要内缩的状况,『:set ai』即提供自 动内缩的功能,用下例解释的: .vi test .(进入编辑窗口後) this is the test for auto indent 《Tab》start indent ← :set ai (设自动内缩) 《Tab》data 《Tab》data 《Tab》data ← :set noai (取消自动内缩) the end of auto indent. .注: 可删除《Tab》字符。
..ex指令 ======= 读写文件 :w 将缓冲区的文件写入磁盘中。 :10,20w test 将第10行至第20行的文件写入test文件。 :10,20w>>test 将第10行至第20行的文件加在test文件的後。 :r test 将test文件的文件读入编辑缓冲区的最後。
删除、复制及搬移 :10,20d 删除第10行至第20行的文件。 :10d 删除第10行的文件。 :$d 删除整个编辑缓冲区。 :10,20co30 将第10行至第20行的文件复制至第30行的後。 :10,20mo30 将第10行至第20行的文件搬移至第30行的後。
字符串搜寻与取代 s(substitute)指令可搜寻某行列范围。 g(global)指令则可搜寻整个编辑缓冲区的文件。 s指令以第一个满足该条件的字符串为其取代的对象,若该行有数个满足该条 件的字符串,也仅能取代第一个,若想取代所有的字符串则需加上g参数。 :1,$s/old/new/g 将文件中所有的『old』改成『new』。 :10,20s/^/ / 将第10行至第20行文件的最前面插入5个空白。 :$s/old/new/g 将编辑缓冲区中所有的『old』改成『new』。
..恢复编辑时被中断的文件 ======================= 在编辑过程中,若系统当掉或连线中断,而缓冲区的文件并还未 被写回磁盘时,当再度回到系统,执行下列指令即可回复中断前 的文件内容。 $vi -r filename
..编辑多个文件 ============= vi亦提供同时编辑多个文件的功能,方法如下: $vi file1 file2 ..
当第一个文件编修完成後,可利用『:w』将该缓冲区存文件,而後 再利用 『:n』载入下一个文件。
|