質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
R

R言語は、「S言語」をオープンソースとして実装なおした、統計解析向けのプログラミング言語です。 計算がとても速くグラフィックも充実しているため、数値計算に向いています。 文法的には、統計解析部分はS言語を参考にしており、データ処理部分はSchemeの影響を受けています。 世界中の専門家が開発に関わり、日々新しい手法やアルゴリズムが追加されています。

Q&A

解決済

1回答

965閲覧

R list to data frame

NNNKKK

総合スコア11

R

R言語は、「S言語」をオープンソースとして実装なおした、統計解析向けのプログラミング言語です。 計算がとても速くグラフィックも充実しているため、数値計算に向いています。 文法的には、統計解析部分はS言語を参考にしており、データ処理部分はSchemeの影響を受けています。 世界中の専門家が開発に関わり、日々新しい手法やアルゴリズムが追加されています。

0グッド

1クリップ

投稿2017/03/21 03:59

###前提・実現したいこと
ここに質問したいことを詳細に書いてください
listをフラットなMatrixもしくはData frameに変換することを試行しています。
対象Listは異なるアイテム数をもっており、扱いに苦戦しております。
最終的な出力イメージはこのような感じです。
Rでのシンプルに記述法についてご教授頂ければ助かります。

X1 X2 X3 1 1 2 3 2 4 5 NA 3 7 8 9 4 10 11 NA

###該当のソースコード

l <- list(a = list(var.1 = 1, var.2 = 2, var.3 = 3) , b = list(var.1 = 4, var.2 = 5) , c = list(var.1 = 7, var.2 = 8, var.3 = 9) , d = list(var.1 = 10, var.2 = 11) ) df <- data.frame(matrix(unlist(l), nrow=4, byrow=T)) X1 X2 X3 1 1 2 3 2 4 5 7 3 8 9 10 4 11 1 2

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

私も勉強途上なので、もっとエレガントな方法が他にあるかもしれませんが、腕試しでチャレンジしてみたところ下記の作戦でうまくいきました。

  1. 行ごとの要素数の最大値を求める
  2. 要素数の少ない行に対し、NAを補う
  3. 行数・桁数を明示的に指定してdfに変換

R

1l <- list(a = list(var.1 = 1, var.2 = 2, var.3 = 3) 2 , b = list(var.1 = 4, var.2 = 5) 3 , c = list(var.1 = 7, var.2 = 8, var.3 = 9) 4 , d = list(var.1 = 10, var.2 = 11) 5) 6 7l.nrow <- length(l) 8l.ncol <- max(sapply(l, length)) 9l.new <- lapply(l, function(x){return(c(x, rep(NA, l.ncol-length(x)) ))}) 10 11l.df <- data.frame(matrix(unlist(l.new), nrow=l.nrow, ncol=l.ncol, byrow=T))
> l.df X1 X2 X3 1 1 2 3 2 4 5 NA 3 7 8 9 4 10 11 NA

投稿2017/06/02 04:04

KojiDoi

総合スコア13669

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問