Beefy Boxes and Bandwidth Generously Provided by pair Networks
good chemistry is complicated,
and a little bit messy -LW

Re^5: putting text into array word by word

by Not_a_Number (Parson)
on Jan 09, 2012 at 20:11 UTC ( #947068=note: print w/ replies, xml ) Need Help??

in reply to Re^4: putting text into array word by word
in thread putting text into array word by word

OK, now that's solved, let's look at the definition of 'word' (yes, things are going to get hairy...). Take this sentence, for example:

"No, he said."

The 'words' that your current code would extract are:

"No, he said."

Is that really what you want? Or would you prefer:

No # or, better, 'no' he said


Comment on Re^5: putting text into array word by word
Select or Download Code
Replies are listed 'Best First'.
Re^6: putting text into array word by word
by jms53 (Monk) on Jan 09, 2012 at 23:19 UTC
    during the foreach loop I remove punctuation and set to lowercase (such that No and no are the same word.
    while (<FILE>) { my @these_words = split(' ', $_); foreach my $this_word (@these_words) { $this_word =~ s/[[:punct:]]//g; $this_word = lc($this_word); push @all_words, $this_word; } }
      $this_word =~ s/[[:punct:]]//g;

      The only problem with that approach is that it removes internal punctuation (ie apostrophes) as well, so that I'll becomes ill, she'd becomes shed, etc. ('Why was Virgina Woolf so obsessed with sheds?' I hear someone ask.)

      I'd use this instead:

      $this_word =~ s/^[[:punct:]]+//; # Remove leading punct. $this_word =~ s/[[:punct:]]+$//; # Remove trailing punct.

      Update: added Virginia Woolf sentence.

        hadn't thought about that. Good catch, thanks!

Log In?

What's my password?
Create A New User
Node Status?
node history
Node Type: note [id://947068]
and the web crawler heard nothing...

How do I use this? | Other CB clients
Other Users?
Others romping around the Monastery: (3)
As of 2015-11-28 04:01 GMT
Find Nodes?
    Voting Booth?

    What would be the most significant thing to happen if a rope (or wire) tied the Earth and the Moon together?

    Results (737 votes), past polls