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

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

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

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

Q&A

解決済

1回答

1487閲覧

data.tableで複数列の代入を行う

退会済みユーザー

退会済みユーザー

総合スコア0

R

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

0グッド

0クリップ

投稿2020/03/24 13:54

前提・実現したいこと

data.tableで複数列の代入を行いたい。

  • year, id, deg, clo の4列から成るデータフレームdf_outputを作成。

 ※データテーブルを使いたかったので、変換。

  • year, idは、予め必要な組み合わせを設定。
  • deg, cloの2列に、算出した結果を代入したい。(df_outputには適当な値(-1)を置いた。)
  • df_outputに算出結果deg_x, clo_xを代入したい。

 ※(year==2018)&(id==555)は、とりあえずの具体例。

degのみ(代入する列1つのみの場合)は、問題なく実行できている。

R

1df_output <- data.frame(code=eg$Var1, id=eg$Var2, deg=-1) 2df_output[(year==2018)&(id==555), deg:=deg_x]

よろしくお願い致します。

該当のソースコード

R

1install.packages("data.table") 2library(data.table) 3 4d <- read.csv(file='test.csv', header=T, sep=",", fileEncoding = "UTF-8") 5 6# year, id, deg, clo の4列から成るdf_outputを作成 7list_code <- unique(d$year) #年度 8list_id <- unique(d$id)     #企業ID 9eg <- expand.grid(list_year, list_id)  #year, idで重複あり組み合わせ 10df_output <- data.frame(code=eg$Var1, id=eg$Var2, deg=-1, clo=-1) #dataframe作成 #deg, cloが算出結果 11df_output <- data.table(df_output) 12 13#deg, cloの算出 14deg_x <- deg算出結果 15clo_x <- clo算出結果 16 17#data.tableへの代入 18df_output[(year==2018)&(id==555), deg:=deg_x, clo:=clo_x] 19

発生している問題・エラーメッセージ

`[.data.table`(df_output, (code == i_code) & (id == でエラー: Provide either by= or keyby= but not both

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

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

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

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

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

guest

回答1

0

ベストアンサー

投稿2020/03/24 14:52

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問