ChinaUnix.net 首页 | 博客 | Linux | 论坛 | 人才 | 培训 | 知识库 | 资料 | 读书 | 手册 | 精华 | 下载 | 沙龙 | 搜索
Linux首页 | Linux论坛 | 论坛精华 | 开源新闻 | 技术文章 | 专题专栏 | 新手指南 | 迁移方案 | 产品方案 | 开源项目 | 开源图书 | 软件下载 | 人才招聘 | Linux博客
  搜索

  产品与方案
·中科红旗全面打造现代化邮政体系
·红旗助力“网上审批服务” 推动电子政务
·红旗正版化开创呼和浩特网吧建设新起点
·红旗Linux助信息产业部邮件服务器“快跑”
·中标普华Linux 为电子政务信息化保驾护航
·中标普华Linux助力基金产业
·中标普华Office率先支持UOF标准
·中标普华邮件系统助力西藏政府信息化建设
·红旗Linux助力国库集中支付系统改革
·红旗助中信卫星 掀起GIS通信应用风暴
·红旗软件助力烟草总局 全面建设“数字烟草”
·红旗助力“信访阳光工程”打造畅通信访渠道
·红帽联合FIS发布下一代实时核心银行平台
·红旗助力金盾 打造全无忧出入境信息系统
·红旗Linux全力打造中国邮政总局名址信息库
·爱尔兰证交所从Unix迁移到红帽企业Linux
·一流的意大利银行选择使用红帽企业Linux
·PLUS Finanzservice选择使用红帽企业Linux
·红帽助力TransACT Communications 公司
·法国零售业巨头Lapeyre采用Redhat Linux
·旅游预订网站选择使用红帽企业Linux
·马哈拉施特拉邦政府的红帽解决之道
·美国联邦政府案例
·红帽为慕尼黑展览会提供现代化集群系统
·Yuba郡用开源软件和红帽产品提高了效率
·红帽企业Linux助印度理工建立高性能计算中心
·采用红帽Linux 将系统维护时间缩短了65%
·从UNIX迁移到Linux使Peñoles公司获益非浅
·Hikal公司用红帽企业Linux开展任务关键的ERP项目
·KDE3.5.4新版本发布
·芝加哥商业交易所从Unix向Linux迁移
·南方基金管理有限公司成功案例 Red Hat Linux
·广东北电通讯设备有限公司成功案例
·挪威国家石油公司从UNIX迁移到红帽Linux,成本减半
·中央电视台CCTV动画部案例 Red Hat Linux

  图书

鸟哥的Linux私房菜基础学..


Linux程序设计.第3版


Linux设备驱动开发详解


  下载
·Endian Firewall
·linux kernel(Linux 内核)
·CentOS
·Fedora Core 6
·Scientific Linux
·Slackware 11.0
·Gentoo Linux
·ubuntu-6.10-i386服务器版本
·ubuntu-6.10-amd64服务器版
·ubuntu-6.10-i386桌面版
·ubuntu-6.10-amd64桌面版
·Engarde Linux
您的位置: Linux时代 > 技术文档 > 程序开发 >

vi 中的正则表达式

日期:2006-10-16 作者:Ivn 来自:linuxfans


 vi 中的正则表达式 (Regular Expression)
===================================
.1. 定义和例子
============
  正则表达式只是一个字符模板,用来在搜索中匹配相同的字符.
在大多数的程序中,正则表达式是括在正斜杠中间的.
例如, /love/就是一个以正斜杠为分隔符的正则表达式,其中的
模板love 将用在搜索所有行中与它匹配的字符. 更为有趣的是
正则表达式可以被特殊的元字符控制.让我们通过下面的例子来进
一步了解这个概念.
  有文本如下:
  Hi tom,
  I think I failed my anatomy test yesterday. I
  had a terrible stomach ache. I ate too many
  fried green tomatoes.
  Anyway, Tom, Ineed your help. I'd like to make
  the test up tomorrow, but don't know where to
  begin studying. Do you think you could help me?
  After work, about 7 PM, come to my place and I'll
  treat you to pizza in return for your help.
  Thanks.
            Your pal,
            guy@phantom

  假设你发觉Tom 并没有参加考试,而是David 参加的考试.同时还
发现, 在贺信中Tom的T用的是小写.于是你决定做一个全文替换,把tom
替换为Tom.

在vi命令行模式下输入:
:1, $s/tom/David/g
 ^   ^  ^    ^   ^
 |   |  |    |   |---- global 对全文有效
 |   |  |    |
 |   |    |--------- 将tom 替换为 David , 使用正则表达式.
 |   |------- 替换单词
 |------ 从文件的第一行到文件的最后一行.

 替换后的文本如下:
 Hi David,
 I think I failed my anaDavidy test yesterday, I
 had terible sDavidach ache. I ate too many
 fried green Davidatoes.
 Anyway, David, I need your help. I'd like to make
 the test up Davidorrow, but don't know where to
 begin studying. Do you think you could help me?
 After work, about ? PM, come to my place and
 I'll treat you to pizza in return for your help.
 Thanks.
                 Your pal,
                 guy@phanDavid
 
 我们发现有些单词中含有tom的的也被替换了.
 这是因为我们没有使用正则表达式的元字符来界定一个模板从而控制
 字符的替换动作.
 使用:
 :1, $s/\<[Tt]om\>/David/g
 就可以得到我们想要的结果了,即只替换单词tom而不是含有tom字符的
 单词.

.2. 正则表达式的元字符
==================
  正则表达式的元字符是一些特殊的字符,它们允许你以某种方式界定一个
模板来控制什么样的替换将发生.有的元字符锚定一个单词在行首或者行尾.
有的元字符允许你指定一个字符范围或者一些字符, 来找到大写字母, 小写字母
数字或者非数字等.

  有两套正则表达式字符集, 一套是基本元字符集, 另一套是扩展元字符集.
另外, POSIX (Portable Operating System Interface for Computer Eaviron ment)
标准还提供了一套元字符集.下表提供了可以在所有版本的vi, grep, egrep, sed and gawk
中使用的基本元字符集.
  表:
----------------------------------------------------------------------------------------------
  元字符      | 功能            |  例子         |  匹配什么
  ----------------------------------------------------------------------------------------------
  ^      | 锚定行的开始         | /^love/   |  匹配所有以love开头的行.
  ----------------------------------------------------------------------------------------------
  $      | 锚定行的结束         | /love$/   |  匹配所有以love结束的行.
  ----------------------------------------------------------------------------------------------
  .      | 匹配一个字符         | /l..e/   |  匹配这样的行, 这些行包含这样的字符,
      |            |      |第一个字符是 l,紧跟着两个字符,然后是e.
  -----------------------------------------------------------------------------------------------
  *      | 代表0个或多个先前字符      | /*love/   |  匹配这样的行, 有0个或者多个空格,空格
      |            |      |候跟着love
  -----------------------------------------------------------------------------------------------
  []      | 匹配字符组中的一个字符      | /[lL]ove/   |  匹配所有包含love or Love 的行
  -----------------------------------------------------------------------------------------------
  [x-y]      | 匹配以字符范围组成的组中的一个字符   | /[A-Z]ove   |  匹配所有这样的行, 这些行包含如下字符
      |            |      |第一个字符是从A到Z 中间的一个, 后面跟
      |            |      |着ove
  -----------------------------------------------------------------------------------------------
  [^]      | 匹配一个不在范围内的字符      | /[^A-Z]ove/   |  匹配所有这样的行, 这些行包含如下字符
      |            |      |第一个字符不是从A到Z 中间的一个, 后面
      |            |      |跟着ove
  -----------------------------------------------------------------------------------------------
  \      | 用来转义一个字符         | /love\./   |  匹配所有这样的行, 这些行包含如下字符
      |            |      |love 后面跟着一个点, 通常点是表示任何
      |            |      |字符的通配符.
  -----------------------------------------------------------------------------------------------
  \<       | 锚定单词的开始         | /\<love/   |  匹配所有这样的行, 这些行包含以love
      |            |      |开头的单词 (vi & grep 都支持这个功能)
  -----------------------------------------------------------------------------------------------
  \>      | 锚定单词的结束         | /<love\>   |  ... ^ ... 以love结束的单词 ... ^
  -----------------------------------------------------------------------------------------------
  \(..\)   | 标记后面用到的匹配字符      | /\(love\)a\1b | 最多可以使用9个标签. 第一个标签是模板
      |            |      |最左边的部分. 在这例子中, 模板love
      |            |      |保存为标签1, 后面的\1指的就是love;
      |            |      |本例子搜索的是这样的行, 这些行包含这样
      |            |      |的字符,在lovea 后面跟着loveb.
 ------------------------------------------------------------------------------------------------
 [NOTE: 各种版本的Unix 以及模板匹配 (pattern-matching) 实用程序并不都是可信赖的, 通常我们使用 vi & grep]

假设你熟悉 vi 是怎样工作的, 每一个元字符都在 vi 搜索字符串的术语中有详细描述.
 下面的例子中, 被加重的字符就是 vi 将找到的匹配字符.
 
 文本如下:
 I had a lovely time on our little picnic.
 Lovers were all around us. It is springtime. Oh
 Love, how much I adore you. Do you know
 the extent of my love? Oh, by the way, I think
 I lost my gloves somewhere out in that field of
 clover. Did you see them? I can only hope love
 is forever. I live for you. It's hard to get back
 in the groove.
 ~
 ~
 ~
 /love/

 结果如下:
 I had a lovely time on our little picnic.
      ^
 Lovers were all around us. It is springtime. Oh
    ^
 Love, how much I adore you. Do you know
   ^
 the extent of my love? Oh, by the way, I think
                    ^
 I lost my gloves somewhere out in that field of
              ^
 clover. Did you see them? I can only hope love
    ^                                        ^
 is forever. I live for you. It's hard to get back
 in the groove.
   
 //
 还有一些测试命令如下:
 /^love/
 /love$/
 /l.ve/
 /[lL]ove/
 /ove[a-z]/
 /ove[^a-zA-Z0-9]/

 //
 //:~ Tue 22 Apr 2003 11:42:51 PM CST
 //:~ End Of PAGE 1

原文链接:http://www.linuxfans.org/nuke/modules.php?name=Forums&file=viewtopic&t=19714

本文被浏览



 相关新闻

开发者发行版:Vine Linux 4.0 Beta 12006-09-01 09:38:52
Linux/Unix 版本SPECviewperf v9 正式提供下载2006-08-25 13:33:08
技巧:Vimdiff 使用2006-08-07 15:51:44
SUSE Linux Enterprise Desktop 10 review2006-08-04 13:51:05


 相关评论
关于我们 | 联系方式 | 广告合作 | 诚聘英才 | 网站地图 | 免费注册

Copyright © 2001-2006 ChinaUnix.net All Rights Reserved

感谢所有关心和支持过ChinaUnix的朋友们

京ICP证041476号