Tag: 命令



19 三 09

前言:我们常常需要收集服务器的信息,硬件的来补充硬件表,服务器的流量、连接数来监控服务器状态等都需要收集,而且还会想把收集过来的信息通过邮件或者excel表显示出来,等等。计划写了个比较强的综合性的服务器收集程序,现在下面先展示的是一个硬件信息收集的程序
这个程序的特点:适应slackware和centos redhat系列的系统,还有需要安装dmidecode 这个可以统计到空闲的PCI槽 物理内存的数量和大小 还可以统计CPU的物理个数和类型等。最后可以结合转excel脚本转换成excel文件。最后就可以形成了一张表。

 
#!/bin/bash
 
# -------------------------------------------------------------------------------
# Filename:    system_info.sh
# Revision:    1.1
# Date:        2008/12/30
# Author:      Ajian
# Email:       ajian521#gmail.com
# Website:     www.ohlinux.com
# Description: get the infomation of the system ,eg: memory,cpu ,etc
# Notes:       can check one or many sites
# -------------------------------------------------------------------------------
# Copyright:   2009 (c) Ajian
# License:     GPL
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty
# of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# -------------------------------------------------------------------------------
#Version 1.1
#get the infomation about , hostname OS CPU CPU_num CPU_Phy  Mem_inuse Mem_Phy disk disk_inuse
#
Hostname=`hostname | cut -d. -f1`
#echo $Hostname
if [ ! -f /etc/slackware-version ]
then
OS=`cat /etc/issue | head -1`
else
OS=`cat /etc/slackware-version | head -1`
fi
 
#echo $OS
CPU=`cat /proc/cpuinfo | grep "model name" | head -1 | cut -d: -f2`
#echo $CPU
CPU_Phy=`cat /proc/cpuinfo | grep phy | sort | uniq | wc -l`
#echo $CPU_Phy
CPU_num=`cat /proc/cpuinfo | grep ^process | wc -l`
#echo $CPU_num
CPU_core=$(( $CPU_num / $CPU_Phy ))
#echo $CPU_core
 
Mem_inuse=`free -m | grep Mem | awk '{print $2}'`
Mem_Phy=`dmidecode -t 17 | grep "Size" | cut -d: -f2 | sort | uniq -c | awk '{printf "%s ",$0}'`
#echo $Mem_inuse
#echo $Mem_Phy
Disk=`fdisk -l | grep Disk | grep GB | cut -d, -f1 | cut -d/ -f3 | awk '{printf "%s  ",$0}'`
#echo $Disk
Disk_inuse=`df -h | grep ^/dev | awk '{print $1,$6,$2}' |  awk '{printf "%s  ",$0}'`
#echo $Disk_inuse
 
echo -e "$Hostname\t$OS\t$CPU\t$CPU_Phy*$CPU_core\t$Mem_inuse MB\t$Mem_Phy\t$Disk\t$Disk_inuse" > ; /tmp/systeminfo.txt






16 二 09

上次介绍了cssh这个批处理工具,这个工具的优点是可图形化批处理工作,如果要远程通过命令或者计划任务来执行多台服务器的话就得用pssh这个工具了。安装pssh就不说了,举个pssh使用的例子。

环境:我们的WEB是nginx+fastcgi的架构,在配置的初期经常会遇到不稳定的情况,如出现502,在没有解决问题之前,如果总是登陆服务器执行相同的重启服务命令是很烦人的,所以在自己的本本上用pssh来执行省去了很多事。

命令如下:

/usr/bin/parallel-ssh -t 10 -h /home/ajian/host -l root -o /tmp/restarlog/ “killall -9 php-cgi && /home/php-fpm-www-product.sh start”

-t  处理超时时间
-h 主机文件,文件内容是一个主机一行 主机[:端口] [用户] 如果都是默认的 或者跟当前用户一样 就只杂IP
-l 用户名
-o 输出执行结果的位置
最后加命令多条命令用引号并且用相关连接符号变成一条执行的命令。

这样是不是觉得还是很不方便用aliase变成一条自己的简单命令就方便多了

alias do-restartcgi=’/usr/bin/parallel-ssh -t 10 -h /home/ajian/host -l root -o /tmp/restarlog/ “killall -9 php-cgi && /home/php-fpm-www-product.sh start”‘

放入到用户要目录下的.bashrc

另外 还有几个工具一样是很实用

parallel-rsync   批处理同步文件

parallel-scp      批处理传送文件

parallel-scp -h hosts.txt -l root .vimrc /root







14 一 09

1.交换两个字符位置

xp

2.上下两行调换

ddp

3.把文件内容反转

:g/^/m0

4.上下两行合并

J

5.删除所有行

dG

6.从当前位置删除到行尾

d$

7.从当前位置复制到行尾

y$ 如果要粘贴到其他地方 p 就可以了

由于vi 是建立在 EX 上的 所以 当键入 : 时就来到了 EX 命令状态

8.

:ab string strings

例如 “:ab usa United States of America” ,

当你在文见里插入 usa 时

United States of America 就蹦出来了

9.

:map keys new_seq

定义你当前 键盘命令

10.

:set [all]

vi or ex 的编辑状态

如 显示每行 :set nu

11.

在命令状态下,nyy表示拷贝从光标行起的下n行内容,p表示paste,可刚复制的内容粘贴在光标处的下面。

12.

单个字符替换用r,覆盖多个字符用R,用多个字符替换一个字符用s,整行替换用S

13.

:%s/old_word/new_word/g

这个指令是于在整个文件中替换特定字符串

14.光标控制

k:上移 nk 上移n行

j:下移 nj 下移n行

将光标移到第n行,按下 mk

将光标移到第m行,按下 “ay’k

即将第n到m的行存到a寄存器,以此类推,b,c……..寄存器等

这样就可以将你常用的需要复用的内容粘贴到不同的寄存器中以备用

想粘贴到某处,直接将光标移到某地,按下 ‘ap 即可,以此类推,b,c……..寄存器等

在当前屏幕中

H 跳到第一行

M 跳到中间一行

L 跳到最后一行

15.

表8-2 删除命令

删除命令操作

d l 删除当前字符(与x命令功能相同)

d 0 删除到某一行的开始位置

d ^ 删除到某一行的第一个字符位置(不包括空格或TA B字符)

d w 删除到某个单词的结尾位置

d 3 w 删除到第三个单词的结尾位置

d b 删除到某个单词的开始位置

d W 删除到某个以空格作为分隔符的单词的结尾位置

d B 删除到某个以空格作为分隔符的单词的开始位置

d 7 B 删除到前面7个以空格作为分隔符的单词的开始位置

d) 删除到某个语句的结尾位置

d 4) 删除到第四个语句的结尾位置

d( 删除到某个语句的开始位置

d } 删除到某个段落的结尾位置

d { 删除到某个段落的开始位置

d 7 { 删除到当前段落起始位置之前的第7个段落位置

d d 删除当前行

d /t e x t 删除从文本中出现” t e x t”中所指定字样的位置,一直向前直到下一个该字样所出现的

位置(但不包括该字样)之间的内容

d fc 删除从文本中出现字符”c”的位置,一直向前直到下一个该字符所出现的位置(包括

该字符)之间的内容

d tc 删除当前行直到下一个字符” c”所出现位置之间的内容

D 删除到某一行的结尾

d $ 删除到某一行的结尾

5 d d 删除从当前行所开始的5行内容

d L 删除直到屏幕上最后一行的内容

d H 删除直到屏幕上第一行的内容

d G 删除直到工作缓存区结尾的内容

d 1 G 删除直到工作缓存区开始的内容

修改命令操作

c l 更改当前字符

c w 修改到某个单词的结尾位置

c 3 w 修改到第三个单词的结尾位置

c b 修改到某个单词的开始位置

c W 修改到某个以空格作为分隔符的单词的结尾位置

c B 修改到某个以空格作为分隔符的单词的开始位置

c 7 B 修改到前面7个以空格作为分隔符的单词的开始位置

c 0 修改到某行的结尾位置

c) 修改到某个语句的结尾位置

c 4) 修改到第四个语句的结尾位置

c( 修改到某个语句的开始位置

c } 修改到某个段落的结尾位置

c { 修改到某个段落的开始位置

c 7 { 修改到当前段落起始位置之前的第7个段落位置

c tc 修改当前行直到下一个字符c所出现位置之间的内容

C 修改到某一行的结尾

c c 修改当前行

5 c c 修改从当前行所开始的5行内容

.重复上一次修改!

表8-4 替换命令

替换命令操作

s 将当前字符替换为一个或多个字符

S 将当前行替换为一个或多个字符

5 s 将从当前字符开始的5个字符替换为一个或多个字符

vi替换使用规则:

:g/s1/s/s2/s3/g

第一个g表示对每一个包括s1的行都进行替换,第二个g表示对每一行包括s1的行所有的s2都用s3替换

s表示替换,s2是要被替换的字符串,他可以和s1相同(如果相同的话用//代替),s3是替换字符串

16.

fx

往右移动到 x 字符上

Fx

往左移动到 x 字符上

tx

往右移动到 x 字符前

Tx

往左移动到 x 字符后

(注意:以上四个命令中,其中x是键入的字符)

;

分号,配合 f 和 t 使用,重复一次

,

逗号,配合 f 和 t 使用,反方向重复一次

17. vi 环境选项 Solaris ksh

noautoindent nomodelines noshowmode

autoprint nonumber noslowopen

noautowrite nonovice tabstop=8

nobeautify nooptimize taglength=0

directory=/var/tmp paragraphs=IPLPPPQPP LIpplpipnpbtags=tags /usr/lib/tags

noedcompatible prompt tagstack

noerrorbells noreadonly term=vt100

noexrc redraw noterse

flash remap timeout

hardtabs=8 report=5 ttytype=vt100

noignorecase scroll=11 warn

nolisp sections=NHSHH HUuhsh+c window=23

nolist shell=/bin/ksh wrapscan

magic shiftwidth=8 wrapmargin=0

mesg noshowmatch nowriteany

For C-Shell:

setenv EXINIT “set nu”

For Bourne or Korn Shell:

EXINIT=”set nu”; export EXINIT

For Korn Shell Only (alternate method):

typeset -x EXINIT=”set nu”

在 .profile 里设置 vi 的环境选项 , 以上均测试过

18.标记文本

mchar

用字母char标记当前光标的位置

`char

移至char所标记处

‘char

移至char标记所在行的开头处

移至当前行上一次所在位置(在光标移动之后)――一个双引号

移至当前行上第一次所在位置的行的开头处(在光标移动之后)――两个单引号

19.

同时vi多个文件时,CTRL-SHIFT-6回到上一个文件,在本次vi的文件和上次vi的文件之间切换。

但是我发现一个BUG:在用CTRL-SHIFT-6切换到上一个文件后,用:args查看多文件vi状态时,

屏幕底部仍然显示目前vi的是刚才的文件。

(在HP-UX,Solaris,AIX上通过)

也可以使用:

:e#

进行切换

20.

sco 下VI 要在文本前同样的字符加用

%s/^/要加的内容/g 要在文本后同样的字符加

%s/$/要加的内容/g

21.

如何去掉文本中的 ^M 硬回车?不必用binary传回去再ascii传回来的方式,用shell或者unix语句实现。

cat filename |tr -d ‘\015′ >newfile

不同的unix系统还存在一些其他不同的命令,如:doscp

sed 也可以实现这个功能.

dos2unix filename filename2

反之

unix2dos filename filename2

在vi 中用:$s/^M//g

^是crtl-V crtl-M

22.如何在”unix命令行”下将一个文件的某字符串用另一个串换掉

sed ’s/string1/string2/gp’ file1 > file2

23.将/etc/hosts下所有的地址都ping 2次

1 #/usr/bin/sh

2 #grad /etc/hosts and ping each address

3 cat /etc/hosts|grep -v ‘^#’ | while read LINE

4 do

5 ADDR=`awk ‘{print $1}’`

6 for MACHINE in $ADDR

7 do

8 ping $MACHINE -n 2

9 done

10 done

24

到前一个函数[[ ,到下一个函数]] ,括号配对% ,交叉参考Ctrl_] (事先用ctags做索引),回来用e# ` 编辑一个函数:vi -t 函数名 ,编辑加密文本vi -X

25

在插入模式下ctrl+p,自动补齐剩余单词,以赖规则:tags,以有的单词等等

当今世界,文本编辑器种类繁多,大有”乱花渐欲迷人眼”之势。中国有句古语:手巧不如家什妙,作为IT业的专业人士,选择一款优秀的编辑软件至关重要。笔者认为:LINUX下的VIM※以其强大的功能和无穷的魅力将使您终生受益。

作者:闫石 (iloveibm@163.com)

来自:http://www-900.ibm.com/developerWorks/cn/linux/l-tip-prompt/tip15/index.shtml

由于被广泛移植,无论是PC机的DOS和WINDOWS,还是RISC/6000的AIX,乃至于IBM的大型机S/390,都能见到VIM的身影。然 而,对于初学者,VIM的用户界面与使用方法非常不符合常规,甚至认为它比较混乱,无所适从。事实上,VIM编辑器是专门为经验丰富的用户设计的,它的界 面和使用方法提供了更快的速度和更强的功能。对于熟知它的用户,VIM的许多特性节省了时间和击键次数,并可以完成一些其他编辑器无法完成的功能。

学习的最好方法是实践,唯有如此,才能真正掌握其中的精髓。文中列举的实例,都是笔者在实际工作中遇到的,具有一定的代表性,请大家在阅读的过程中仔细体会。

好了,现在让我们共同畅游神奇的VIM的世界!

例一、两个常用的指令序列

xp 左右交换光标处两字符的位置。

ddp 上下交换光标处两行的位置。

例二、重复输入同一字符

有时,我们可能想多次输入同一字符,VIM的插入功能可以很好的完成这项工作

命令 80i=^ESC 一次可以输入80个字符= ,当然,80a=^ESC 也可以完成上述功能。

请注意:此处的^ESC表示键盘左上方上的ESC键。

例三、将两个文本数据文件按行逐条合并,并给出标尺

数据文件1内容如下:

1—–

2—–

3—–

数据文件2内容如下:

1=====

2=====

3=====

要求的结果如下:

|——–1———2———3———4———5

1—–

1=====

|——–1———2———3———4———5

2—–

2=====

|——–1———2———3———4———5

3—–

3=====

也许您会说,这还不简单,无非是反复拷贝、粘贴,任何一款文本编辑器都能完成上述功能。可是,如果这两个文件都很大,每个文件都成千上万行,恐怕简单的 拷贝、粘贴就难以胜任了。因此,我们所关心的,是找到一种行之有效的方法,把枯燥乏味的工作留给计算机,我们只需发布指令。为达到此目的,请按以下步骤执 行:

㈠、将两文件合并,结果如下

1—–

2—–

3—–

1=====

2=====

3=====

㈡、在两文件头尾相接的地方插入标志行,用以区分两个文件,本文采用的是一整行!字符

1—–

2—–

3—–

!!!!!!!!!!!!!!!!!!!!!!!!

1=====

2=====

3=====

㈢、在标志行的下方输入标尺

1—–

2—–

3—–

!!!!!!!!!!!!!!!!!!!!!!!!

|——–1———2———3———4———5

1=====

2=====

3=====

㈣、执行宏命令脚本merge_2r.vim,即在VIM编辑器中按如下键 :so merge_2r.vim 回车

㈤、按下键盘上的=键,执行的结果如下

|——–1———2———3———4———5

1—–

1=====

|——–1———2———3———4———5

2—–

2=====

|——–1———2———3———4———5

3—–

3=====

|——–1———2———3———4———5

!!!!!!!!!!!!!!!!!!!!!!!!

|——–1———2———3———4———5

㈥、将最后三行删除,即可得到我们需要的结果

|——–1———2———3———4———5

1—–

1=====

|——–1———2———3———4———5

2—–

2=====

|——–1———2———3———4———5

3—–

3=====

怎么样,简单吗?请大家自己实际尝试一下。下面,我来详细讲解宏命令脚本merge_2r.vim 。

该脚本内容如下:

“——————————————————————–

“Macro Function : Merge File1 And File2,Have Ruler in every record

” Date : 2001/12/01

” Author : Yan Shi

“——————————————————————–

“1—–

“2—– } Sample File1

“3—–

“!!!!!!!!!!!!!!!!!!!!!!!! Flag Row

“|——–1———2———3———4———5 Ruler

“1=====

“2===== } Sample File2

“3=====

“——————————————————————–

:1

:map = ma/!!!!!^M+:.co ‘a-1^M/!!!!!^M2+:.m’a^M+=

前14行每行都以”开始,表明该行是注释行,实际并不执行,只是方便读者阅读,只有最后两行才是真正的代码行。请注意:本例中的^M表示键盘上的回车键,并非^和M两个字符。为了讲述清楚,我把命令行分解开,逐一说明。

首先将第一行置为当前行,然后执行map命令,将一大串VIM指令映像给字符=。这一大串VIM指令共分9步执行:

ma 将数据文件一的第一行标记为a

1—–

2—–

3—–

!!!!!!!!!!!!!!!!!!!!!!!!

|——–1———2———3———4———5

1=====

2=====

3=====

/!!!!!^M 找到标志行,置为当前行

1—–

2—–

3—–

!!!!!!!!!!!!!!!!!!!!!!!!

|——–1———2———3———4———5

1=====

2=====

3=====

+ 光标下移一行,即把标尺行置为当前行

1—–

2—–

3—–

!!!!!!!!!!!!!!!!!!!!!!!!

|——–1———2———3———4———5

1=====

2=====

3=====

:.co ‘a-1^M 把标尺行复制到标记行(数据文件一的第一行)的上方

|——–1———2———3———4———5

1—–

2—–

3—–

!!!!!!!!!!!!!!!!!!!!!!!!

|——–1———2———3———4———5

1=====

2=====

3=====

/!!!!!^M 再次找到标志行,置为当前行

|——–1———2———3———4———5

1—–

2—–

3—–

!!!!!!!!!!!!!!!!!!!!!!!!

|——–1———2———3———4———5

1=====

2=====

3=====

2+ 光标下移2行,即数据文件二的第一行置为当前行

|——–1———2———3———4———5

1—–

2—–

3—–

!!!!!!!!!!!!!!!!!!!!!!!!

|——–1———2———3———4———5

1=====

2=====

3=====

:.m’a^M 把数据文件二的第一行移至标记行的下方

|——–1———2———3———4———5

1—–

1=====

2—–

3—–

!!!!!!!!!!!!!!!!!!!!!!!!

|——–1———2———3———4———5

2=====

3=====

+ 光标下移一行,即数据文件一的第二行置为当前行

|——–1———2———3———4———5

1—–

1=====

2—–

3—–

!!!!!!!!!!!!!!!!!!!!!!!!

|——–1———2———3———4———5

2=====

3=====

= 这一步很关键,是典型的递归调用,重复完成以上步骤

例四、在文件中置入行号

工作中,我们有时希望把行号置入文件中,而VIM提供的功能 :set nu 只能显示行号,不能编辑或将其置入文件当中,下面的宏命令脚本row_num.vim可以完成此项功能。

“——————————————

“Macro Function : Source File Add Row_Num

” Date : 2001/12/01

” Author : Yan Shi

“——————————————

:%s/^/^I/

:$

:let end=line(”.”)

:1

“——————————————

:let num=1

:while num<=end

:let line=getline(”.”)

:let temp=substitute(line,$,num,”")

:call setline(”.”,temp)

:+

:let num=num+1

:endwhile

“——————————————

请注意:本例中的^I表示键盘上的TAB键,并非^和I两个字符。下面,我针对该宏命令脚本逐一讲解。

:%s/^/^I/ 每一行的行首添加一个TAB字符

:$ 到文件的末行

:let end=line(”.”) 末行的行号 ==〉变量 END,函数line的功能是取得指定行的行号,此处参数”.”表示当前行

:1 到文件的首行

“——————————————

:let num=1 1 ==〉计数器

:while num<=end

:let line=getline(”.”) 取当前行的内容 ==〉变量 LINE

:let line=substitute(line,$,num,”") 在变量 LINE 的前面置入行号

:call setline(”.”,line) 将变量 LINE 的内容写回当前行

:+ 下移一行

:let num=num+1 计数器加一

:endwhile 循环执行,直到文件结束

“——————————————

有关正则表达式的使用

UNIX/LINUX下的很多工具之所以强大、灵活,关键是因为有了正则文法和元字符,这也是VIM乃至UNIX/LINUX系统的精华所在。正因为使 用灵活,因此掌握起来比较吃力,如果不是真正理解,实际运用中会出现千奇百怪的错误。因此,有必要对这部分知识多花些气力。下面结合具体实例讲解。

例五、有一文件,包含某外企的中国员工的资料,首先是姓名,然后是两个空格,其次是15位身份证号码。

zhang.fei 430759701022003

diao.chan 651302801225012

guan.yu 342869680413001

xi.shi 120638780214006

liu.bei 210324650708001

现在,有以下问题需要解决:

按照外国人的习惯,应该是名在前,姓在后。因此,文件中的姓名字段需要修改。

姓与名的首字母应该大写。

根据身份证号码,还可以判断出生年月日,将其作为一个新字段添加。

根据身份证号码,可以判断出性别。若为男性,添加male,若为女性,添加female 。

将男女员工分开,男员工在前,女员工在后。

将各字段数据左对齐

最终结果如下:

Fei.Zhang 430759701022003 1970/10/22 male

Yu.Guan 342869680413001 1968/04/13 male

Bei.Liu 210324650708001 1965/07/08 male

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

Chan.Diao 651302801225012 1980/12/25 female

Shi.Xi 120638780214006 1978/02/14 female

为了完成上述功能,只需执行脚本employee.vim ,使用方法为 :so employee.vim 回车即可。

脚本内容如下:

:%s/ / /

:%s/\(…………\)\( *\)/\1/

:%s/\([A-Za-z][A-Za-z]*\)\(\.\)\([A-Za-z][A-Za-z]*\)/\u\3\2\u\1/

:%s/$/ xxxxxx/

:%s/\([0-9]\{6}\)\([0-9]\{6}\)\([0-9]\{3}\) \(xxxxxx\)/\1\2\3 \2/

:%s/\(..\)\(..\)\(..\)$/19\1\/\2\/\3

:%s/$/ xxxxxx/

:%s/\([0-9]\{14}[13579]\)\(.*\)\(xxxxxx\)/\1\2male /

:%s/\([0-9]\{14}[02468]\)\(.*\)\(xxxxxx\)/\1\2female/

:$

:s/.*/&^M———————————————–

:g/female/.m$

在这个脚本中,使用了大量的正则表达式,这里仅对涉及到的正则表达式做一简要介绍。有关正则表达式的内容相当多,本文不可能占用大量篇幅叙述,请大家谅解。

% 地址范围符号,代表文件中的所有行,作用等同于地址范围 1,$

. 与任意单字符(换行符除外)匹配,例如 y.s 可以匹配 yas y.s 或 y s 等等。

* 与前一字符的0次或多次出现匹配,例如 y*s 可以匹配 yys yyyyys 或 s 等等。

$ 与行尾匹配。

& 代表模式匹配中出现的字符串,例如 s/abc/&def 是把当前行的abc替换成abcdef 。

[] 匹配[]中出现的字符,例如[abc]匹配字符 a,b 或 c ,[a-zA-Z]匹配所有的英文字符。

\( \) \(和\)之间出现的内容可以由\num来替代。

\1\2\3 替代\(和\)之间出现的内容。

\u 将后续字符串的首字母大写。

\{num} 与前一字符的num次出现匹配。

现在,我们对脚本逐条讲解,希望能帮助大家理解正则文法。

⑴:%s/ / /

将文件中每行出现的2个空格替换为10个空格。

zhang.fei 430759701022003

diao.chan 651302801225012

guan.yu 342869680413001

xi.shi 120638780214006

liu.bei 210324650708001

⑵:%s/\(…………\)\( *\)/\1/

保留行首的12个字符,将其余的空格删除,这样,前两个字段就对齐了。

zhang.fei 430759701022003

diao.chan 651302801225012

guan.yu 342869680413001

xi.shi 120638780214006

liu.bei 210324650708001

⑶:%s/\([A-Za-z][A-Za-z]*\)\(\.\)\([A-Za-z][A-Za-z]*\)/\u\3\2\u\1/

将文件中每行出现的雇员姓名互换,并将首字母大写。

Fei.Zhang 430759701022003

Chan.Diao 651302801225012

Yu.Guan 342869680413001

Shi.Xi 120638780214006

Bei.Liu 210324650708001

⑷:%s/$/ xxxxxx/

在每一行的行尾添加2个空格和6个x

Fei.Zhang 430759701022003 xxxxxx

Chan.Diao 651302801225012 xxxxxx

Yu.Guan 342869680413001 xxxxxx

Shi.Xi 120638780214006 xxxxxx

Bei.Liu 210324650708001 xxxxxx

⑸:%s/\([0-9]\{6}\)\([0-9]\{6}\)\([0-9]\{3}\) \(xxxxxx\)/\1\2\3 \2/

将xxxxxx替换成出生年月日。

Fei.Zhang 430759701022003 701022

Chan.Diao 651302801225012 801225

Yu.Guan 342869680413001 680413

Shi.Xi 120638780214006 780214

Bei.Liu 210324650708001 650708

⑹:%s/\(..\)\(..\)\(..\)$/19\1\/\2\/\3

将年月日用/字符分隔,并在年前添加19。

Fei.Zhang 430759701022003 1970/10/22

Chan.Diao 651302801225012 1980/12/25

Yu.Guan 342869680413001 1968/04/13

Shi.Xi 120638780214006 1978/02/14

Bei.Liu 210324650708001 1965/07/08

⑺:%s/$/ xxxxxx/

在每一行的行尾添加2个空格和6个x

Fei.Zhang 430759701022003 1970/10/22 xxxxxx

Chan.Diao 651302801225012 1980/12/25 xxxxxx

Yu.Guan 342869680413001 1968/04/13 xxxxxx

Shi.Xi 120638780214006 1978/02/14 xxxxxx

Bei.Liu 210324650708001 1965/07/08 xxxxxx

⑻:%s/\([0-9]\{14}[13579]\)\(.*\)\(xxxxxx\)/\1\2male /

身份证号码末位是奇数的,将xxxxxx替换成male

Fei.Zhang 430759701022003 1970/10/22 male

Chan.Diao 651302801225012 1980/12/25 xxxxxx

Yu.Guan 342869680413001 1968/04/13 male

Shi.Xi 120638780214006 1978/02/14 xxxxxx

Bei.Liu 210324650708001 1965/07/08 male

⑼:%s/\([0-9]\{14}[02468]\)\(.*\)\(xxxxxx\)/\1\2female/

身份证号码末位是偶数的,将xxxxxx替换成female

Fei.Zhang 430759701022003 1970/10/22 male

Chan.Diao 651302801225012 1980/12/25 female

Yu.Guan 342869680413001 1968/04/13 male

Shi.Xi 120638780214006 1978/02/14 female

Bei.Liu 210324650708001 1965/07/08 male

⑽:$ 到文件的最后一行

⑾:s/.*/&^M———————————————–

在文件的最末行插入一行 “-” 字符。

Fei.Zhang 430759701022003 1970/10/22 male

Chan.Diao 651302801225012 1980/12/25 female

Yu.Guan 342869680413001 1968/04/13 male

Shi.Xi 120638780214006 1978/02/14 female

Bei.Liu 210324650708001 1965/07/08 male

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

⑿:g/female/.m$

将所有的女员工记录移至文件尾。

Fei.Zhang 430759701022003 1970/10/22 male

Yu.Guan 342869680413001 1968/04/13 male

Bei.Liu 210324650708001 1965/07/08 male

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

Chan.Diao 651302801225012 1980/12/25 female

Shi.Xi 120638780214006 1978/02/14 female

笔者目前正在为某外资公司从事大型机(IBM S/390)的软件开发,一切工作都在TSO环境中进行。为了对编写的程序进行测试,必须准备测试数据。有过大型机开发经验的人会知道,通过TSO,输入 字符型数据还可以,如果要输入16进制数据,操作起来很麻烦。因为16进制数是纵向排列的,输入时既不方便,又很容易错位。怎么解决呢?我尝试了几种办 法,实际证明,用VIM最方便。

例六、下列数据 1234567890ABCDEF ,将其变成 13579ACE 24680BDF 的形式,这样,数据就可以很方便的粘贴到TSO环境中了。

下面给出宏命令脚本change_d.vim

“—————————————————-

“Macro Function : Convert Char Arrange Direction

” Sample : 40 50 60 ==> 4 5 6

” 0 0 0

” Date : 2001/12/01

” Author : Yan Shi

“—————————————————-

:s/.*/&^M/

:1

:map = malx+$p-`al=

说明如下:

⑴ :s/.*/&^M/ 在数据行下方添加一空行。

⑵ :1 回到文件的首行的首字符。

⑶ :map = malx+$p-`al= 将一大串VIM命令映像给字符=

① ma 将首字符标记为a

② l 光标右移一个字符

③ x 删除光标处字符

④ + 移至下一行

⑤ $ 到行尾

⑥ p 将删除的字符粘贴

⑦ – 回至上一行

⑧ `a 返回到标记字符处

⑨ l 光标右移一个字符

⑩ = 递归调用,重复以上步骤,直到将该行所有的数据处理完。







14 一 09

移动光标
上:k nk:向上移动n行 9999k或gg可以移到第一行 G移到最后一行
下:j nj:向下移动n行
左:h nh:向左移动n列
右:l nl:向右移动n列

w:光标以单词向前移动 nw:光标向前移动n个单词 光标到单词的第一个字母上
b:与w相反
e: 光标以单词向前移动 ne:光标向前移动n个单词 光标到单词的最后一个字母上
ge:与e相反

$:移动光标到行尾 n$:移动到第n行的行尾
0(Num):移动光标到行首
^:移动光标到行首第一个非空字符上去

f:移动光标到当前行的字符a上,nf移动光标到当前行的第n个a字符上
F:相反

%:移动到与制匹配的括号上去(),{},[],<>等。

nG:移动到第n行上 G:到最后一行

CTRL+G 得到当前光标在文件中的位置

向前翻页:CTRL+F
向下移动半屏:CTRL+G
向后翻页:CTRL+B

存盘:
:q! :不存盘退出
:e! :放弃修改文件内容,重新载入该文件编辑
:wq :存盘退出

dw:删除一个单词,需将光标移到单词的第一个字母上,按dw,如果光标在单词任意位置,用daw
dnw:删除n个单词
dne:也可,只是删除到单词尾
dnl:向右删除n个字母
dnh:向左删除n个字母
dnj:向下删除n行
dnk:向上删除n行
d$:删除当前光标到改行的行尾的字母
dd:删除一行
cnw[word]:将n个word改变为word
cc:改变整行
C$:改变到行尾

J: 删除换行符,将光标移到改行,按shift+j删除行尾的换行符,下一行接上来了.
u: 撤销前一次的操作
shif+u(U):撤销对该行的所有操作。

:set showmode :设置显示工作模式

o:在当前行的下面另起一行
O(shift+o):在当前行的上面另起一行

nk或nj:光标向上或向下移n行,n为数字
an!【ESC】:在行后面加n个感叹号(!)
nx:执行n次x(删除)操作

ZZ:保存当前文档并退出VIM

:help :查看帮助文档,在这之中,按CTRL+] 进入超连接,按CTRL+O 返回。
:help subject :看某一主题的帮助,ZZ 退出帮助

:set number / set nonumber :显示/不显示行号
:set ruler /set noruler:显示/不显示标尺

/pattern 正方向搜索一个字符模式
?pattern 反方向搜索一个字符模式
然后按n 继续向下找

把光标放到某个单词上面,然后按×号键,表示查找这个单词
查找整个单词:/

:set hlsearch 高亮显示查找到的单词
:set nohlsearch 关闭改功能

m[a-z]:在文中做标记,标记号可为a-z的26个字母,用`a可以移动到标记a处

r:替换当前字符
nr字符:替换当前n个字符

查找替换:
way1:
/【word】 :查找某个word
cw【newword】:替换为新word
n: 继续查找
.: 执行替换

way2:
:s/string1/string2/g:在一行中将string1替换为string2,g表示执行 用c表示需要确认
:num1,num2 s/string1/string2/g:在行num1至num2中间将string1替换为string2
:1,$ s/string1/string2/g:在全文中将string1替换为string2

v:进入visual 模式
【ESC】退出
V:shift+v 进入行的visual 模式
CTRL+V:进如块操作模式用o和O改变选择的边的大小。

粘贴:p,这是粘贴用x或d删除的文本
复制:
ynw:复制n个单词
yy:复制一行
ynl:复制n个字符
y$:复制当前光标至行尾处
nyy:拷贝n行
完了用p粘贴

:split:分割一个窗口
:split file.c :为另一个文件file.c分隔窗口
:nsplit file.c: 为另一个文件file.c分隔窗口,并指定其行数
CTRL+W在窗口中切换
:close:关闭当前窗口

在所有行插入相同的内容如include<,操作方法如下:
将光标移到开始插入的位置,按CTRL+V进入VISUAL模式,选择好模块后
按I(shift+i),后插入要插入的文本,按[ESC]完成。

:read file.c 将文件file.c的内容插入到当前光标所在的下面
:0read file.c 将文件file.c的内容插入到当前文件的开始处(第0行)
:nread file.c 将文件file.c的内容插入到当前文件的第n行后面
:read !cmd :将外部命令cmd的输出插如到当前光标所在的下面

:n1,n2 write temp.c 将本文件中的n1,到n2行写入temp.c这个文件中去

CTRL+L刷新屏幕
shift + < 左移一行
shift + > 右移一行

u: undo
CTRL+R: re-do
J: 合并一行
CTRL+p 自动完成功能
CTRL+g 查看当前文件全路径

q[a-z] 开始记录但前开始的操作为宏,名称可为【a-z】,然后用q终止录制宏。
用reg显示当前定义的所有的宏,用@[a-z]来在当前光标处执行宏[a-z].