1. Học hỏi
  2. /
  3. Khoa Học
  4. /
  5. Rで学ぶSentiment Analysis

Connected

Bài tập

Tidy Text の Tibble を作成しましょう!

tidy の考え方を学んだので、このコードでデータを tibble に整理し、tidyverse で作業できるようにします。

以前、TermDocumentMatrix() オブジェクトに tidy() を適用すると、TDM が tibble に変換されることを学びました。今回は、comments というレビュー列から、単語データを直接作成します。

まずは unnest_tokens() を使って、テキストを小文字化し、レビューを単語ごとにトークン化します。

コーパスの各グループ内で、元の単語順を保持したいことがあります。その場合は mutate() を使います。mutate() の中で seq_along() を使い、オブジェクトの長さに応じて 1 からの連番を作成します。これで、記述されたとおりの単語順を保持できます。

tm パッケージでは、ストップワードを削除するのに removeWords() を使います。tidyverse では、まずストップワード辞書を読み込んでから、整形したテキストデータフレームとストップワードの間で anti_join() を適用します。

Hướng dẫn

100 XP
  • 元のレビューオブジェクト bos_reviews をパイプ(%>%)で unnest_tokens() に渡し、tidy_reviews を作成します。新しい列名として word を指定し、comments 列を宣言します。tidyverse では $ や引用符は不要です。
  • 新しい変数を tidy な方法で作成します。tidy_reviews を group_by にパイプして id 列でグループ化し、さらに %>% で mutate() に渡します。mutate の中で、新しい変数 original_word_order を seq_along(word) として作成します。
  • tibble の tidy_reviews を出力します。
  • 事前作成された「SMART」ストップワードを data("stop_words") で R セッションに読み込みます。
  • もとの tidy_reviews を anti_join() に %>% で渡して上書きします。anti_join() の中には、あらかじめ用意された stop_words 辞書を渡します。