The "$" at the end of your regex means 'match only if "R" followed by five digits' is at the END of your line of data. That said, there are numerous guesses already as to what your data might really look like (Hint: code tags!), so here's another. It may be relevant if your data looks like that in the code below:

#!/usr/bin/perl use 5.014; #994367 my @data = ( 'R00005: 00330: C01010 => C00011', 'R00005: 00791: C01010 => C00011', 'R00005: 01100: C01010 <=> C00011', 'R00006: 00770: C00022 => C00900', 'R00008: 00362: C06033 => C00022', 'R00008: 00660: C00022 => C06033', 'R00010: 00500: C01083 => C00031', 'R00013: 00630: C00048 => C01146', 'R00013: 01100: C00048 <=> C01146', ); for my $data (@data) { if ( $data =~ /(R\d{5}).+)/ ) { # Match on and capture any line +which # contains the sequence R, 5 dig +its, and # something more # The parens in the regex captur +e the # match to $1 (but are not used +here) # which could be used in other a +pplications. say "\t Match on data $data. Hooray!"; } else { say "No match on data $data"; } } # do it again for those beginning "R00005" ONLY say "\n\n doing it again for 'R00005' ONLY"; for my $data (@data) { if ( $data =~ /(R0{4})(5)(.+)/ ) { say "\t Match on data " . $1 . $2 . $3 . " Hooray!"; # 3 capt +ures, # print' +em # NOT a good pr +actice; # illustrate ON +LY one aspect # of regex capt +ures } else { say "No match on data $data"; } } =head output: Match on data R00005: 00330: C01010 => C00011. Hooray! Match on data R00005: 00791: C01010 => C00011. Hooray! Match on data R00005: 01100: C01010 <=> C00011. Hooray! Match on data R00006: 00770: C00022 => C00900. Hooray! Match on data R00008: 00362: C06033 => C00022. Hooray! Match on data R00008: 00660: C00022 => C06033. Hooray! Match on data R00010: 00500: C01083 => C00031. Hooray! Match on data R00013: 00630: C00048 => C01146. Hooray! Match on data R00013: 01100: C00048 <=> C01146. Hooray! doing it again for 'R00005' ONLY Match on data R00005: 00330: C01010 => C00011. Hooray! Match on data R00005: 00791: C01010 => C00011. Hooray! Match on data R00005: 01100: C01010 <=> C00011. Hooray! No match on data R00006: 00770: C00022 => C00900 No match on data R00008: 00362: C06033 => C00022 No match on data R00008: 00660: C00022 => C06033 No match on data R00010: 00500: C01083 => C00031 No match on data R00013: 00630: C00048 => C01146 No match on data R00013: 01100: C00048 <=> C01146 =cut

See perlretut.


In reply to Re: Regex help by ww
in thread Regex help by randomhero1270

Title:
Use:  <p> text here (a paragraph) </p>
and:  <code> code here </code>
to format your post, it's "PerlMonks-approved HTML":



  • Posts are HTML formatted. Put <p> </p> tags around your paragraphs. Put <code> </code> tags around your code and data!
  • Titles consisting of a single word are discouraged, and in most cases are disallowed outright.
  • Read Where should I post X? if you're not absolutely sure you're posting in the right place.
  • Please read these before you post! —
  • Posts may use any of the Perl Monks Approved HTML tags:
    a, abbr, b, big, blockquote, br, caption, center, col, colgroup, dd, del, details, div, dl, dt, em, font, h1, h2, h3, h4, h5, h6, hr, i, ins, li, ol, p, pre, readmore, small, span, spoiler, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, tr, tt, u, ul, wbr
  • You may need to use entities for some characters, as follows. (Exception: Within code tags, you can put the characters literally.)
            For:     Use:
    & &amp;
    < &lt;
    > &gt;
    [ &#91;
    ] &#93;
  • Link using PerlMonks shortcuts! What shortcuts can I use for linking?
  • See Writeup Formatting Tips and other pages linked from there for more info.