Shell正则表达式及练习题

grep 正则表达式练习

grep使用方式
  使用方式:grep [OPTIONS] PATTERN [FILE…]

  grep [OPTIONS] [-e PATTERN | -f FILE] [FILE…]

  常用选项:
  –color=auto:对匹配到的文本着色后进行高亮显示;

   -i:忽略字符的大小写

  -o:仅显示匹配到的字符串

  -v:显示不能被模式匹配到的行

  -E:支持使用扩展的正则表达式

  -q:静默模式,即不输出任何信息

  -A #:显示被模式匹配的行及其后#行

  -B #:显示被模式匹配的行及其前#行

  -C #:显示被模式匹配的行及其前后各#行

  注:使用grep匹配时需使用双引号引起来(单引号为强引用),防止被系统误认为参数或者特殊命令而报错。

扩展grep使用方式
  使用方式:egrep [OPTIONS] PATTERN [FILE…]

  grep -E [OPTIONS] PATTERN [FILE…]

  -i:忽略字符的大小写
  -o:仅显示匹配到的字符串本身
  -v:显示不被模式匹配到的行
  -q:静默模式,即不输出任何信息
  -A #:显示被模式匹配的行及其后#行
  -B #:显示被模式匹配的行及其前#行
  -C #:显示被模式匹配的行及其前后各#行
  -G:支持基本正则表达式

grep正则表达式元字符
  ‘^‘: 锚定行首

  ‘$’: 锚定行尾

  ‘.‘: 匹配任一一个字符

  ‘*’: 匹配零个或多个先前字符

  ‘\?‘:匹配其前面的字符0次或者1次;

  ‘+’:匹配其前面的字符1次或者多次;

  ‘{m}‘:匹配其前面的字符m次(\为转义字符)

  ‘{m,n}’:匹配其前面的字符至少m次,至多n次

  ‘[]‘: 匹配一个指定范围内的字符 | ‘[^]’匹配指定范围外的任意单个字符

  ‘\<‘或‘\b’:锚定词首,‘>’或‘\b’:锚定词尾(可用\

Steve Blenheim:238-923-7366:95 Latham Lane, Easton, PA 83755:11/12/56:20300
Betty Boop:245-836-8357:635 Cutesy Lane, Hollywood, CA 91464:6/23/23:14500
Igor Chevsky:385-375-8395:3567 Populus Place, Caldwell, NJ 23875:6/18/68:23400
Norma Corder:397-857-2735:74 Pine Street, Dearborn, MI 23874:3/28/45:245700
Jennifer Cowan:548-834-2348:583 Laurel Ave., Kingsville, TX 83745:10/1/35:58900
Jon DeLoach:408-253-3122:123 Park St., San Jose, CA 04086:7/25/53:85100
Karen Evich:284-758-2857:23 Edgecliff Place, Lincoln, NB 92086:7/25/53:85100
Karen Evich:284-758-2867:23 Edgecliff Place, Lincoln, NB 92743:11/3/35:58200
Karen Evich:284-758-2867:23 Edgecliff Place, Lincoln, NB 92743:11/3/35:58200
Fred Fardbarkle:674-843-1385:20 Parak Lane, DeLuth, MN 23850:4/12/23:780900
Fred Fardbarkle:674-843-1385:20 Parak Lane, DeLuth, MN 23850:4/12/23:780900
Lori Gortz:327-832-5728:3465 Mirlo Street, Peabody, MA 34756:10/2/65:35200
Paco Gutierrez:835-365-1284:454 Easy Street, Decatur, IL 75732:2/28/53:123500
Ephram Hardy:293-259-5395:235 CarltonLane, Joliet, IL 73858:8/12/20:56700
James Ikeda:834-938-8376:23445 Aster Ave., Allentown, NJ 83745:12/1/38:45000
Barbara Kertz:385-573-8326:832 Ponce Drive, Gary, IN 83756:12/1/46:268500
Lesley Kirstin:408-456-1234:4 Harvard Square, Boston, MA 02133:4/22/62:52600
William Kopf:846-836-2837:6937 Ware Road, Milton, PA 93756:9/21/46:43500
Sir Lancelot:837-835-8257:474 Camelot Boulevard, Bath, WY 28356:5/13/69:24500
Jesse Neal:408-233-8971:45 Rose Terrace, San Francisco, CA 92303:2/3/36:25000
Zippy Pinhead:834-823-8319:2356 Bizarro Ave., Farmount, IL 84357:1/1/67:89500
Arthur Putie:923-835-8745:23 Wimp Lane, Kensington, DL 38758:8/31/69:126000
Popeye Sailor:156-454-3322:945 Bluto Street, Anywhere, USA 29358:3/19/35:22350
Jose Santiago:385-898-8357:38 Fife Way, Abilene, TX 39673:1/5/58:95600
Tommy Savage:408-724-0140:1222 Oxbow Court, Sunnyvale, CA 94087:5/19/66:34200
Yukio Takeshida:387-827-1095:13 Uno Lane, Ashville, NC 23556:7/1/29:57000
Vinh Tranh:438-910-7449:8235 Maple Street, Wilmington, VM 29085:9/23/63:68900
  1. 显示包含 San的行

    grep "San" datafile
  2. 显示以 J 开头的人名所在的行

        grep "^J" datafile
  3. 显示 700 结尾的行

    grep "700$" datafile
  4. 显示不包 834 的行

    grep -v "834" datafile 
  5. 显示生日 12 月的行

    awk -F"[:/]" '{ print $(NF-3)}' datafile 
  6. 显示电话号码的区号为 834 的行

    grep ":834-" datafile
  7. 显示这样的行 : 它包含一个大写字后跟四个小写字母 , 逗号, 空格, 和一个大写 字母

    egrep "[[:upper:]]{1}[[:lower:]]{4},[[:space:]]{1}[[:upper:]]{1}" datafile
  8. 显示姓以 K或 k 开头的行

    grep -i "^k" datafile   
  9. 显示工资为六位数的行 , 并在前面加行号

    egrep "[0-9]{6}$" datafile 
  10. 显示包括 Lincoln 或 lincoln 的行, 并且 grep 对大小写不敏感

    grep -i "lincoln" datafile
  • 5
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Shell 正则表达式是一种用于匹配和处理文本的强大工具。它可以在 Shell 环境中使用,例如 Bash 或其他 Unix Shell正则表达式是一种特殊的字符串模式,用于描述文本的结构和特征。 在 Shell 中,常用的正则表达式语法包括: 1. 字符匹配: - 普通字符:直接匹配输入的字符,例如 `a` 匹配字符 "a"。 - 元字符:具有特殊含义的字符,如 `.` 匹配任意字符,`*` 匹配前一个字符的零个或多个重复。 2. 字符类: - 方括号 `[ ]`:匹配方括号内的任意一个字符,例如 `[abc]` 匹配 "a"、"b" 或 "c"。 - 取反字符类 `[^ ]`:匹配除了方括号内指定的字符之外的任意一个字符,例如 `[^abc]` 匹配除了 "a"、"b" 和 "c" 之外的任意一个字符。 3. 重复次数: - `*`:匹配前一个字符的零个或多个重复。 - `+`:匹配前一个字符的一个或多个重复。 - `?`:匹配前一个字符的零个或一个重复。 - `{n}`:匹配前一个字符的恰好 n 次重复。 - `{n,}`:匹配前一个字符的至少 n 次重复。 - `{n,m}`:匹配前一个字符的 n 到 m 次重复。 4. 锚定符号: - `^`:匹配输入文本的开头。 - `$`:匹配输入文本的结尾。 除了上述语法,还有更多高级的正则表达式功能,如分组、引用、转义字符等。Shell 中常用的正则表达式工具包括 `grep`、`sed`、`awk` 等。 希望以上信息能帮到你!如果你有任何进一步的问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值