前提・実現したいこと
別のデータフレームから条件に合う行を検索し、該当する場合に特定の値を抽出したいです。
インプット
<データフレーム1>
index 局コード 日付 time 番組コード
1 1 4/1 1132 N/A
2 3 4/3 1135 N/A
3 3 4/4 1221 N/A
<データフレーム2>
index 局コード 日付 開始時間 終了時間 番組コード
1 1 4/1 1130 1255 ABC1
2 2 4/1 1130 1256 BBC2
3 3 4/3 1045 1150 CBC3
4 1 4/5 930 955 AAA1
期待する結果
<データフレーム1>
index 局コード 日付 time 番組コード
1 1 4/1 1132 ABC1
2 3 4/3 1135 CBC3
3 3 4/4 1221 N/A
条件としては、双方の'局コード','日付'が一致し、且つデータフレーム1の'time'が
データフレーム2の'開始時間'と'終了時間'の間の値であったときのみ、番組コードを抽出し、データフレーム1の番組コードに代入する。というものを書きたいです。
pythonをはじめたばかりで、書籍で学習しながらも学業の一環でこのような高度な条件設定の記述を用意せねばならず四苦八苦しています。お力添えいただければと思い質問させていただきました。
発生している問題・エラーメッセージ
エラーメッセージ
該当のソースコード
import pandas as pd
mask =(pd.concat([データフレーム1,データフレーム2]).duplicated(subset=['局コード','放送日'], keep=False))
mask
python3, jupyter
試したこと
局コードと放送日が一致する条件の時、concatで結合するという条件まではかけたのですが、timeと開始時間、終了時間の不等号による条件設定ができません。また、現状のconcatではindexが同じ番号のもののみを比較し、trueかfalseかを判別してしまっているのですが、データフレーム1のindex1の条件に該当する行をデータフレーム2全体からサーチし、index最終段まで同様の施行を繰り返すということを実現させたいです。どうかお力添えをお願いいたします。
補足情報(FW/ツールのバージョンなど)
ここにより詳細な情報を記載してください。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2018/11/06 05:32