I would be tempted to go even a little further down the look-around path and specify that the four-digit groups be exactly four digits, i.e., that they be delimited by non-digits.

c:\@Work\Perl>perl -wMstrict -le "my $s = '37 35 55555 37 8 17 16 25 36 37 3840 42 42 42 40'; print qq{'$s'}; ;; $s =~ s{ (?<= (?<! \d) [0-9]{2}) (?= [0-9]{2} (?! \d)) }{ }xmsg; print qq{'$s'}; " '37 35 55555 37 8 17 16 25 36 37 3840 42 42 42 40' '37 35 55555 37 8 17 16 25 36 37 38 40 42 42 42 40'

The OPed example data contain an instance of a single-digit data point: '37 8 17'. If I saw such a two-one-two pattern in the output, how would I know (other than by going back and examining the original data) that it was not a regex fix-up artifact?

c:\@Work\Perl>perl -wMstrict -le "my $s = '37 35 55555 37 8 17 16 25 36 37 3840 42 42 42 40'; print qq{'$s'}; ;; $s =~ s{ (?<= [0-9]{2}) (?= [0-9]{2}) }{ }xmsg; print qq{'$s'}; " '37 35 55555 37 8 17 16 25 36 37 3840 42 42 42 40' '37 35 55 5 55 37 8 17 16 25 36 37 38 40 42 42 42 40'
Of course, there aren't any five-digit groups in the original data, right? Famous Last Words. This is, at least potentially, an illustration of the classic regex lament "I had a problem and I thought, 'I know, I'll solve it with a regex!' Now I have two problems." Much as I love regexes, I have to admit they can turn nasty on ya pretty quickly. Best to be precise.

Update: Come to think of it, if single-digit data values are valid, who's to say that the proper representation of '3840' is not '3 84 0'? More information is needed to make a useful decision here.


Give a man a fish:  <%-(-(-(-<


In reply to Re^3: substituting capture groups substrings (?...) by AnomalousMonk
in thread substituting capture groups substrings by naturalsciences

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.