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

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

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

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

Q&A

解決済

1回答

982閲覧

Rで横持ちファイルを縦持ちファイルに変換する方法

essa

総合スコア81

R

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

0グッド

0クリップ

投稿2019/02/25 14:21

標記について質問させてください。

やりたいことは、横持ちファイルを縦持ちファイルにする方法です。
参考にしているサイトは
https://hato.yokohama/yokotate/#toc5
です。

R

1library('tidyr') 2library('dplyr') 3df = read.table(file = '~/Desktop/analysis/blog/input/yoko.csv', header = TRUE) 4df
idnameX20170401X20170501X20170601
1sato102030
2kondo100200300

R

1# df : data.frame 2# gather : データフレームをアンピボットする関数 3# key = date : アンピボット対象の列名をセットする列名 4# value = qty : アンピボット対象の値をセットする列名 5# X20170401:X20170601 : アンピボットする列名 6df.gather <- df %>% 7 tidyr::gather( key = date, value = qty, X20170401:X20170601) 8df.gather
idnamedateqty
1satoX2017040110
2ondoX20170401100
1atoX2017050120
2ondoX20170501200
1atoXX2017060130
2kondoX20170601300

これを複数列でやりたいです。

例えば、
|id|name|X20170401|X20170501|X20170601|Y0170401|Y20170501|Y20170601
|:--:|:--:|:--:|:--:|:--:|
1|sato|10|20|30|10|20|30|
2|kondo|100|200|300|100|200|300|

とあった場合、XはXで、YはYだけでまとめたいです。
|id|name|Xdate|Xqty|Ydate|Yqty|
|:--:|:--:|:--:|:--:|
というような感じです。

単純に

R

1df.gather <- df %>% 2 tidyr::gather( key = Xdate, value = Xqty, X20170401:X20170601) 3df.gather 4df.gather <- df.gather %>% 5 tidyr::gather( key = Ydate, value = Yqty, Y20170401:Y20170601)

としたら
Error: cannot allocate vector of size 1.2 Gb
というエラーが起きました
※実際のファイルは、上記のようなものではなく、かなり重いファイルです。

どのように実現できるでしょうか。
ご存知の方がいましたら、ご教示いただけますと嬉しいです。

どうぞよろしくお願い致します。

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

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

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

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

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

guest

回答1

0

ベストアンサー

データが大きすぎてメモリに入りきれないということのようですから、元データを10000行づつとか少しづつ読んでは処理してappendしていくしか無いのではないでしょうか。

投稿2019/02/25 14:30

KojiDoi

総合スコア13671

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

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

essa

2019/03/15 10:18

KojiDoi様 回答ありがとうございます。 そのようにしました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問