Rのデータフレームにおいて、ファクター列を2値に変換する方法をお伝えいたします。
方法はとても単純で、データフレームの列ごとにファクター型かどうかをチェックし、ファクター型であればファクターごとに2値の列を新たに作成し追加します。
ソースコードは以下のようになります。


convertFactorToBinary <- function(df, sep = ".") {
  l <- list()
  for (i in 1:ncol(df)) {
    if ("factor" %in% class(df[[i]]) &&
        !("ordered" %in% class(df[[i]]))) {
      m <- sapply(levels(df[[i]]), function(x)
        as.integer(x == df[[i]]))
      for (j in 1:ncol(m)) {
        l[[paste(colnames(df)[i], colnames(m)[j], sep = sep)]] <- m[, j]
      }
    } else{
      l[[colnames(df)[i]]] <- df[[i]]
    }
  }
  return(data.frame(l))
}

データセットwarpbreaksを用いて実際に試してみます。
まずは、データセットの内容を確認します。


> data("warpbreaks")
> print(str(warpbreaks))
'data.frame':	54 obs. of  3 variables:
 $ breaks : num  26 30 54 25 70 52 51 26 67 18 ...
 $ wool   : Factor w/ 2 levels "A","B": 1 1 1 1 1 1 1 1 1 1 ...
 $ tension: Factor w/ 3 levels "L","M","H": 1 1 1 1 1 1 1 1 1 2 ...

> print(head(warpbreaks))
  breaks wool tension
1     26    A       L
2     30    A       L
3     54    A       L
4     25    A       L
5     70    A       L
6     52    A       L

次に、ファクター型の列を変換してみます。


> res <- convertFactorToBinary(warpbreaks, sep = "_") > print(str(res))
'data.frame':	54 obs. of  6 variables:
 $ breaks   : num  26 30 54 25 70 52 51 26 67 18 ...
 $ wool_A   : int  1 1 1 1 1 1 1 1 1 1 ...
 $ wool_B   : int  0 0 0 0 0 0 0 0 0 0 ...
 $ tension_L: int  1 1 1 1 1 1 1 1 1 0 ...
 $ tension_M: int  0 0 0 0 0 0 0 0 0 1 ...
 $ tension_H: int  0 0 0 0 0 0 0 0 0 0 ...

> print(head(res))
  breaks wool_A wool_B tension_L tension_M tension_H
1     26      1      0         1         0         0
2     30      1      0         1         0         0
3     54      1      0         1         0         0
4     25      1      0         1         0         0
5     70      1      0         1         0         0
6     52      1      0         1         0         0

ファクター列が2値になっていることが確認できました。

関連する記事

  • R言語 CRAN Task View:統計教育R言語 CRAN Task View:統計教育 CRAN Task View: Teaching Statisticsの英語での説明文をGoogle翻訳を使用させていただき機械的に翻訳したものを掲載しました。 Maintainer: Paul Northrop Contact: p.northrop at […]
  • Ubuntu 20.04にDockerをインストールする手順Ubuntu 20.04にDockerをインストールする手順 Ubuntu 20.04にDockerをインストールおよびインストールの確認、sudoなしでdockerコマンドを実行する方法をお伝えします。 Ubuntu 20.04にDockerをインストールする方法はいくつかありますが、snapを用いた方法、Ubuntuの標準リポジトリを用いた方法、DockerおよびDocker […]
  • 教師あり学習と教師なし学習のふわっとした説明教師あり学習と教師なし学習のふわっとした説明 機械学習の教師あり学習と教師なし学習について、難しい専門用語を全く使わずに概要を分かりやすく説明してみます。 プログラムとは まず、プログラムについてふわっと説明します。 このページをご覧になられているということは、ブラウザと呼ばれるプログラム(例えば、Google ChromeやMicrosoft Edge、Mozilla Firefox、Apple […]
  • R言語 CRAN Task View:心理モデルや手法R言語 CRAN Task View:心理モデルや手法 CRAN Task View: Psychometric Models and Methodsの英語での説明文をGoogle翻訳を使用させていただき機械的に翻訳したものを掲載しました。 Maintainer: Patrick Mair Contact: mair at […]
  • R言語 CRAN Task View:ベイズ推論R言語 CRAN Task View:ベイズ推論 CRAN Task View: Bayesian Inferenceの英語での説明文をGoogle翻訳を使用させていただき機械的に翻訳したものを掲載しました。 Maintainer: Jong Hee Park Contact: jongheepark at […]
R データフレームのファクター列を2値に変換する方法