SED多个搜索项目

时间:2016-11-20 23:00:17

标签: sed

SED问题

我需要打印11月份包含11或12月份包含12行的所有行。

我的两个问题是:

  1. 如何搜索多个项目。打印值为11和12的行?
  2. 如何告诉搜索在第4列中查看哪些日期?
  3. 到目前为止我所拥有的:

    sed -n -e '/11/,/12/p' datebook
    

    档案datebook

    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
    

2 个答案:

答案 0 :(得分:1)

  

如何告诉搜索在第4列中查看哪些日期?

这表明您应该使用awk因为sed没有字段的概念。 awk解决方案将是

awk -v FS=":" '$4 ~ /^1[12]\/.*/{print}' datebook

<强>输出

Steve Blenheim:238-923-7366:95 Latham Lane, Easton, PA 83755:11/12/56:20300
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
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

解密解决方案

  • FS=":"将字段/列分隔符设置为冒号。
  • $4代表输入文件中的第四列,即mm/dd/yy
  • 格式的日期
  • ~中的$4 ~ /^1[12]\/.*/表示我们正在进行正则表达式匹配
    • ^表示字符串的开头
    • [12]可以匹配一两个。
    • 由于正则表达式部分本身由/分隔,因此您需要转义任何文字/,如\/

答案 1 :(得分:0)

您似乎想要选择行第三个冒号后的第一个字符为11/12/的行(因为数据格式似乎是Y2K之前的US格式日期为mm/dd/yy符号)。所以你写道:

$ sed -n '/^\([^:]*:\)\{3\}1[12]\//p' datebook
Steve Blenheim:238-923-7366:95 Latham Lane, Easton, PA 83755:11/12/56:20300
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
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
$

^在一行开头匹配; \([^:]*]:\)部分查找一系列零个或多个非冒号后跟冒号; \{3\}需要其中3个;之后1[12]\/要求11/12/; p打印。

我观察到最初的陈述说“11月份包含11或12月份包含12”,但您的第一个编号问题是“价值11和12”。这些是矛盾的;给定的日期字段只能以一个开始,而不是两个。我认为'或'就是你想要的。