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

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

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

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

634閲覧

Python Pandas 行の抽出と結合

退会済みユーザー

退会済みユーザー

総合スコア0

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2019/06/24 07:58

df_preds['0']において、欠損値がある行番号とない行番号を抽出します。
dfの、df_preds['0']における欠損値がない行番号の行全てをdf_x_trainに繋げていきます。
dfの、df_preds['0']における欠損値がある行番号の行全てをdf_x_testに繋げていきます。
df_predsの、df_preds['0']における欠損値がない行番号の行全てをdf_t_trainに繋げていきます。

上記を実装したところ、エラーが発生しました。
どなたか、解決方法を教えて頂けると幸いです。

python

1df_x_test = df_preds 2df_x_train = df_preds 3df_t_train = df_preds['0'] 4 5for i, j in enumerate(df_preds['0'].isnull()): 6 if j == True: 7 df_x_test = pd.concat(df_x_test, df.loc[i, :]) 8 else: 9 df_x_train = pd.concat(df_x_train, df.loc[i, :]) 10 df_t_train = pd.concat(df_t_train, df_preds.loc[i, '0']) 11

error

1--------------------------------------------------------------------------- 2TypeError Traceback (most recent call last) 3<ipython-input-12-58893862488f> in <module> 4 7 df_x_test = pd.concat(df_x_test, df.loc[i, :]) 5 8 else: 6----> 9 df_x_train = pd.concat(df_x_train, df.loc[i, :]) 7 10 df_t_train = pd.concat(df_t_train, df_preds.loc[i, '0]) 8 11 9 10c:\users\t16cs039\appdata\local\programs\python\python37-32\lib\site-packages\pandas\core\reshape\concat.py in concat(objs, axis, join, join_axes, ignore_index, keys, levels, names, verify_integrity, sort, copy) 11 226 keys=keys, levels=levels, names=names, 12 227 verify_integrity=verify_integrity, 13--> 228 copy=copy, sort=sort) 14 229 return op.get_result() 15 230 16 17c:\users\t16cs039\appdata\local\programs\python\python37-32\lib\site-packages\pandas\core\reshape\concat.py in __init__(self, objs, axis, join, join_axes, keys, levels, names, ignore_index, verify_integrity, copy, sort) 18 242 raise TypeError('first argument must be an iterable of pandas ' 19 243 'objects, you passed an object of type ' 20--> 244 '"{name}"'.format(name=type(objs).__name__)) 21 245 22 246 if join == 'outer': 23 24TypeError: first argument must be an iterable of pandas objects, you passed an object of type "DataFrame"

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

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

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

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

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

guest

回答1

0

ベストアンサー

pandas.concatでデータフレームの結合を行う場合は「連結したいデータフレームを格納したシーケンス型」を渡す必要があります。

pandas.concat — pandas 0.24.2 documentation

なので、df_x_test = pd.concat([df_x_test, df.loc[i, :]])のように書いてください。

もしかしたら他にも問題があるかもしれませんが、再現できるデータがないと検証できないので取り急ぎ目立つ点だけ。

投稿2019/06/24 11:35

hayataka2049

総合スコア30933

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問