2016-11-20 2 views
0

SED FrageSED Mehrere Suchbegriffe

Ich muss alle Zeilen drucken, die 11 für November oder 12 für Dezember enthalten.

Meine beiden Fragen sind:

  1. Wie suche ich für mehr als ein Element I.E. Zeilen mit den Werten 11 und 12 drucken?
  2. Wie sage ich der Suche in Spalte 4 zu suchen, die die Daten hat?

Was ich habe, so weit:

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

Datei 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 
+1

Diese Seite ist international: es auch in den Zustand wäre, dass die Daten in Spalte 4 auftreten, sind im US-Stil Monat/Tag/Jahr Format. Ich sehe auch, dass die Menschen durch die Y2K-Krise schlummern; Es gibt wirklich keinen guten Grund, nicht alle 4 Ziffern des Jahres zu speichern. –

+0

Werfen Sie einen Blick auf http://unix.stackexchange.com/questions/145402/regex-alternation-or-operator-foobar-in-gnu-ur-bsd-sed – BadZen

Antwort

0

Es scheint, dass Sie auswählen Linien wollen, wo die ersten Zeichen nach dem dritten Doppelpunkt auf der Linie 11/ sind oder 12/ (da die Datenformate im US-Format vor dem Jahr 2000 erscheinen, mit der Notation mm/dd/yy). So schreiben Sie:

$ 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 
$ 

Die ^ Matches am Anfang einer Zeile; Der \([^:]*]:\) Teil sucht nach einer Reihe von null oder mehr Nicht-Doppelpunkten, gefolgt von einem Doppelpunkt; die \{3\} erfordert 3 von ihnen; die 1[12]\/ Forderungen 11/ oder 12/ danach; die druckt.

Ich beobachte, dass die erste Aussage sagt "11 für November oder 12 für Dezember enthalten", aber Ihre erste nummerierte Frage sagt "Wert 11 und 12". Diese sind widersprüchlich; ein gegebenes Datumsfeld kann nur mit einem oder das andere beginnen, nicht beides. Ich habe angenommen, dass "oder" du beabsichtigst.

+0

Ja, oder ist was ich meinte. Das hat perfekt funktioniert. Danke auch für die Erklärung. – TonyD

1

Wie kann ich feststellen, die Suche in Spalte 4 zu suchen, welche die Daten hat?

Dies ist ein Indiz dafür, dass Sie awk weil sed nicht über das Konzept der Felder verwendet werden sollen. Die Entzifferung der Lösung

  • FS=":" setzt das das Feld/Spalte Trennzeichen Doppelpunkt eine awk Lösung würde

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

    Ausgabe

    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 
    

    sein.

  • $4 stellt die Spalte vier in Ihrer Eingabedatei, die das Datum im Format mm/dd/yy
  • Die ~ in $4 ~ /^1[12]\/.*/ bedeutet, dass wir in dem tun, um eine Regex
    • ^ stellt den Anfang der Zeichenfolge ist
    • [12] kann entweder eins oder zwei übereinstimmen.
    • Da die Regex Teil selbst durch / begrenzt ist, müssen Sie sich als jede wörtliche / entkommen in \/
Verwandte Themen