1

私は現在、ロングテール SEO の新しいアイデアをいくつか調査しています。私は、人々が独自のブログを作成できるサイトを持っており、すでにかなりのロングテール トラフィックをもたらしています。記事のタイトル タグ内に既に記事のタイトルを表示しています。

ただし、コンテンツ内のキーワードとタイトルがうまく一致しないことがよくあります。php が実際に最適と判断したキーワードをタイトルに追加することに興味があります。

ページで最も一般的な単語が何であるかを理解するために作成したスクリプトを使用してみました。これは問題なく機能しますが、これの問題は、かなり役に立たない言葉が出てくることです。

頻繁に出現するペア (または 3 つのセット) の単語を抽出し、それらを出現頻度順に並べた配列に配置する php スクリプトを作成すると便利だと思いました。

私の問題:より動的な方法でテキストを解析して、繰り返される単語のペアまたはトリプレットを探す方法。これについてどうすればいいですか?

function extractCommonWords($string, $keywords){
  $stopWords = array('i','a','about','an','and','are','as','at','be','by','com','de','en','for','from','how','in','is','it','la','of','on','or','that','the','this','to','was','what','when','where','who','will','with','und','the','www');

  $string = preg_replace('/\s\s+/i', '', $string); // replace whitespace
  $string = trim($string); // trim the string
  $string = preg_replace('/[^a-zA-Z0-9 -]/', '', $string); // only take alphanumerical characters, but keep the spaces and dashes too…
  $string = strtolower($string); // make it lowercase

  preg_match_all('/\b.*?\b/i', $string, $matchWords);
  $matchWords = $matchWords[0];

  foreach ( $matchWords as $key=>$item ) {
      if ( $item == '' || in_array(strtolower($item), $stopWords) || strlen($item) <= 3 ) {
          unset($matchWords[$key]);
      }
  }   
  $wordCountArr = array();
  if ( is_array($matchWords) ) {
      foreach ( $matchWords as $key => $val ) {
          $val = strtolower($val);
          if ( isset($wordCountArr[$val]) ) {
              $wordCountArr[$val]++;
          } else {
              $wordCountArr[$val] = 1;
          }
      }
  }
  arsort($wordCountArr);
  $wordCountArr = array_slice($wordCountArr, 0, $keywords);
  return $wordCountArr;
}
4

1 に答える 1