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

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

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

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Q&A

解決済

1回答

849閲覧

文字列を含む行を削除したい

MOSMOS2

総合スコア20

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

0グッド

0クリップ

投稿2018/12/11 12:02

前提・実現したいこと

indexはそのままで、文字列を含む行を削除したい。
文字列の形式は様々である。

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

input.csv
|name|A|B|C|D
|:--|:--|:--|:--|
getsu| 1| 2| 9| 0
ka| 0| 3| 8| 9
sui| 0| 4|nothing| 3
moku| 2| nan| 1| 4
kin| 3| 9| 1| 5
do| 4| NG| 1| 4
nichi| 5| 5| 1| 2

上記のような表に対して、文字列を含む行を削除したいと思っています。
結果として、suiとmokuとdoが抜けて下記のように出力したいです

output.csv
|name|A|B|C|D
|:--|:--|:--|:--|
getsu| 1| 2| 9| 0
ka| 0| 3| 8| 9
kin| 3| 9| 1| 5
nichi| 5| 5| 1| 2

結果として、name, A, B, C, Dの行しか抽出されないので、indexも入ってしまって、すべての行が落とされているのだろうと感じています。
ご教示いただければ幸いです。
よろしくお願いいたします。

該当のソースコード

Python3

1import pandas as pd 2datapd = pd.read_csv("input.csv", encoding='SHIFT-JIS', index_col=0) 3datapd2 = datapd.drop(index=datapd.select_dtypes(include='object').index) 4datapd2.to_csv("output.csv")

試したこと

index_col = 0 にしたりしましたが、違うようです。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

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

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

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

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

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

hayataka2049

2018/12/12 12:32

"1"という文字列の可能性もありますが、どう区別しましょうか
MOSMOS2

2018/12/12 13:07

"1"は文字列に含まれてしまうのですか?実際には8000x1000行列くらいで、1はたくさん含まれています。この回答でよろしいでしょうか。文字列のパターンも多くて、どれか1個に特定するのが難しい状況です。ですので、がさっと「文字を含むセルを含む行を丸ごと削除」という形にしたいと考えています。
hayataka2049

2018/12/12 13:33

たぶんですが、恐らく全列が型としては文字列で、"1"などは「数字の文字列」として入っていると思われます。整数型や浮動小数点型に変換できるものだけ、あるいは半角数字のみ(or 半角数字+ドット)を含むものだけ、といった条件で取り出し、必要なら数値型に変換して使うことになります。確認ですが、数字はすべて整数と想定して良いですか?
MOSMOS2

2018/12/12 13:53

ありがとうございます。だいぶわかってきました。数字は整数と少数を含むもの、様々です。
guest

回答1

0

ベストアンサー

こんな感じでどうでしょうか。

Python3

1def is_finite_number(x): 2 try: 3 return np.isfinite(float(x)) 4 except ValueError: 5 return False 6 7datapd2 = datapd[datapd.applymap(is_finite_number).all(1)].astype(float)

投稿2018/12/18 05:12

kzm4269

総合スコア184

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

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

MOSMOS2

2018/12/18 11:10

できました!すごい!!(感動)簡単そうで実は結構難しそうだったので難儀していました。ありがとうございました!!大感謝です!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問