php вывод текста с выделенными ключевыми словами - PullRequest
0 голосов
/ 02 марта 2012

У меня есть система, которая выводит обзор фильма, когда он выводится, я хочу, чтобы ключевые слова, которые в нем отображались из 2 таблиц - отрицательные и положительные, были другого цвета, есть идеи?Код ниже

<?php

// Connect to database
mysql_connect("sdd", "sdsd", "") or die(mysql_error());
mysql_select_db("sdsd") or die(mysql_error());

$id = mysql_real_escape_string($_POST['reviewid']); 

//$query = "select * from review where id = '$id'";
$query = mysql_fetch_assoc(mysql_query("SELECT filmreview FROM review WHERE id = '$id'"));
$pos = mysql_query("SELECT word FROM positive");
$neg = mysql_query("SELECT word FROM negative");


//Variables 
$review_text = $query['filmreview'];
$good = 0;
$bad = 0; 


// Gets words in to a text array and converts to lower case 
$cnt_r = array_count_values(array_map('mb_strtolower',str_word_count($review_text, 1)));

// Gets the positive words and check for the word in the text  
    while($check = mysql_fetch_assoc($pos)){
       $lower = mb_strtolower($check['word']);
     if(isset($cnt_r[$lower])){
    $good+= $cnt_r[$lower];
    echo $check ['word'];
    echo "<p>"; 
     } 
    }

// Gets the negative words and check for the word in the text 
while($check = mysql_fetch_assoc($neg)){
  $lower = mb_strtolower($check['word']);
 if(isset($cnt_r[$lower])){
    $bad+= $cnt_r[$lower];
        echo $check ['word'];
        echo "<p>";
 }  
} 


// If there are more positive words than negative than the review is positive  
if ($good > $bad)
{
    echo "<p>"; 
    echo "This is a positive review";
    echo "<p>";
}

// If there are more negative words than positive than the review is negative 
else if ($good < $bad)
{
    echo "<p>";
    echo "This is a negative review";
    echo "<p>";
}

// If there are the same amount of positive and negative words than the review is average 
else if ($good == $bad)
{
    echo "<p>";
    echo "This is an average review";
    echo "<p>";
}

//Prints out the number of postive and negative words found 
echo "Good words: " . $good . " and Bad words: " . $bad;
echo "<p>";
echo $query ['filmreview'];
echo "<p>";
echo "This is <font color=\"blue\">blue</font>!"; 



echo "<form method='post' action='welcome.html'>";
echo "<input type='submit' name='searchagain' value='Search'>";
?>

Ответы [ 3 ]

2 голосов
/ 02 марта 2012

Вы можете использовать классы CSS.

В своей таблице стилей или в теге стиля на своей странице вы можете создать классы CSS:

p .negative { color: red; }
p .positive { color: black; }

Теперь просто добавьте класс в свой абзаци он будет применять стили, которые вы хотите.

// If there are more positive words than negative than the review is positive  
if ($good > $bad)
{
    echo '<p class="positive">'; 
    echo 'This is a positive review';
    echo '</p>';
}

// If there are more negative words than positive than the review is negative 
else if ($good < $bad)
{
    echo '<p class="negative">';
    echo 'This is a negative review';
    echo '</p>';
}

и т.д .....

0 голосов
/ 02 марта 2012
  1. попробуйте прочитать ответ на запрос сразу после его отправки.Таким образом, вы избегаете засорения результатов нескольких запросов.
  2. $cnt_r = array_count_values(array_map('mb_strtolower',str_word_count($review_text, 1))); представляется фракционированной версией $cnt_r = str_word_count(mb_strtolower($review_text), 2);
  3. str_word_count не является многобайтовой безопасностью.В Smarty я использовал preg_match_all('#[\w\pL]+#u', $review_text, $matches); в качестве основы для str_word_count () версии UTF-8.
  4. дает PDO поближе
  5. присвойте своим переменным некоторые идентифицирующие имена
  6. всегда оставляйте ваши выходные данные правильно - htmlspecialchars () всегда будет использоваться!
  7. Это 2012 год - мы никогда не используем тег <font>!Вместо этого используйте CSS!

<?php
$query = mysql_fetch_assoc(mysql_query("SELECT filmreview FROM review WHERE id = '$id'"));
$review_text = $query['filmreview'];

// Gets words in to a text array and converts to lower case 
$review_words = array_count_values(array_map('mb_strtolower',str_word_count($review_text, 1)));

$positive_words = array();
$negative_words = array();
$positive_words_count = 0;
$negative_words_count = 0;

// Gets the positive words and check for the word in the text  
$res = mysql_query("SELECT word FROM positive");
while ($row = mysql_fetch_assoc($res)){
    // why isn't this already stored lower-case in database?
    $_word = mb_strtolower($row['word']);
    if (isset($review_words[$_word])){
        $positive_words_count += $review_words[$_word];
        $positive_words[] = $_word;
    } 
}

// Gets the negative words and check for the word in the text 
$res = mysql_query("SELECT word FROM negative");
while ($row = mysql_fetch_assoc($res)){
    // why isn't this already stored lower-case in database?
    $_word = mb_strtolower($row['word']);
    if (isset($review_words[$_word])){
        $negative_words_count += $review_words[$_word];
        $negative_words[] = $_word;
    }  
}

if ($positive_words_count > $negative_words_count) {
    // If there are more positive words than negative than the review is positive  
    echo "<p>This is a positive review<p>";
} elseif ($positive_words_count < $negative_words_count) {
    // If there are more negative words than positive than the review is negative 
    echo "<p>This is a negative review<p>";
} else {
    // If there are the same amount of positive and negative words than the review is average 
    echo "<p>This is an average review<p>";
}

// highlight positive/negative words
$review_text = htmlspecialchars($review_text);
$pattern = '#\b(' . join('|', $positive_words) . ')\b#i';
$review_text = preg_replace($pattern, "<span class=\"positive\"\\1</span>", $review_text);
$pattern = '#\b(' . join('|', $negative_words) . ')\b#i';
$review_text = preg_replace($pattern, "<span class=\"negative\"\\1</span>", $review_text);

//Prints out the number of postive and negative words found 
echo "Good words: " . $positive_words_count . " and Bad words: " . $negative_words_count;
echo "<p>" . $review_text . "<p>";
echo "This is <font color=\"blue\">blue</font>!"; 

и где-нибудь в вашем CSS определите, как span.negative и span.positive должны выглядеть.

0 голосов
/ 02 марта 2012

Просто найдите и найдите ваши ключевые слова в тексте, а затем просто замените их. Так примерно

    if($postivekeyword) {  
       $newpostivekeyword = '<span class="positive">'.$postivekeyword.'</span>';
   }
    if($negativekeyword) {  
      $newnegativekeyword = '<span class="negative">'.$negativekeyword.'</span>';
    }

Тогда просто

   $new_review_text = str_replace($postivekeyword, $newpostivekeyword, $review_text);
...