I doubt this counts as more elegant, but...
use strict; use warnings; my $text = q{ I need to extract the first several words from a paragraph of text con +tained in a $var, so as to get the longest extract that's less than or equal to 200 char +acters. My brute-force-and-ignorance method is: blah some more text here etc e +tc }; my $chunk; ($chunk) = $text =~ /^(.{1,200})(?<!\s)(?!\w)/; printf "[%d] %s\n", length($chunk), $chunk; $chunk = $text; $chunk =~ s/^(.{200}).*$/$1/; $chunk =~ s/^(.*)\s+\w*$/$1/; printf "[%d] %s\n", length($chunk), $chunk; $chunk = ""; $text =~ s/^\s+//; foreach (split /\s+/, $text) { if (length($chunk) + length($_) <= 200) { $chunk .= $_ . " "; } else { last; } } chop $chunk; printf "[%d] %s\n", length($chunk), $chunk;
Output:
Use of uninitialized value in length at C:\temp\ws.pl line 15. Use of uninitialized value in printf at C:\temp\ws.pl line 15. [0] '' [242] ' I need to extract the first several words from a paragraph of text con +tained in a $var, so as to get the longest extract that's less than or equal to 200 char +acters. My brute-force-and-ignorance method is: blah some more text here etc e +tc ' [194] 'I need to extract the first several words from a paragraph of t +ext contai ned in a $var, so as to get the longest extract that's less than or eq +ual to 200 characters. My brute-force-and-ignorance'

gav^


In reply to Re: Regex: get first N characters but break at whitespace by gav^
in thread Regex: get first N characters but break at whitespace by George_Sherston

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.