'badword1' 'badword2' 'badword3' and so on #### # @keep has all the messages in it. # @keep_after_swear_words should be the filtered version of @keep my $data = qq(SELECT id, word FROM swears); my $sth = $dbh->prepare($data); $sth->execute() or die $dbh->errstr; my ($id, $badword); $sth->bind_columns(\$id, \$badword); foreach my $line (reverse @keep) { my ($username, $message, $date, $ip) = split(//, $line); #print "user: $username
message: $message
date: $date
ip: $ip

"; while ($sth->fetch) { $username =~ s/\b$badword\b/ **** /gi; $message =~ s/\b$badword\b/ **** /gi; } print "message: $message
"; push(@keep_after_swear_words, "$username$message$date$ip"); } #.. print out modified text here