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

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

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

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

Q&A

解決済

1回答

1018閲覧

python3で2次元配列の突き合わせをして値を取り出したい

yanyan1010

総合スコア19

Python 3.x

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

0グッド

0クリップ

投稿2018/07/19 17:55

次のような2次元配列が2つあります。

データ1
重複なし,重複あり
a1,L1
a2,L1
a3,L1
d1,L1
a4,L2
a5,L2
a6,L2
d2,L2

データ2
重複なし,重複なし
d1,L1
d2,L2

データ2にある2列目の重複ありの値(Lで始まる値)を
データ1の2列目(Lで始まる値)と突き合わせして
ヒットする行の列1を抜き出す。
但し、データ2に含まれている列1(Dで始まる値)と同じ値を除外したい。

1列目と2列目の位置は逆転してもかまいません。

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

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

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

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

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

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

hayataka2049

2018/07/20 00:32

「データ2にある2列目の重複ありの値(Lで始まる値)を データ1の2列目(Lで始まる値)と突き合わせして」はデータ2と1が逆では? どちらにせよわかりづらいので、もう少し説明をわかりやすくして、具体的な出力も示してください
guest

回答1

0

ベストアンサー

pandas 使って書いてみましたが、こういう事ですか?

Python

1import pandas as pd 2 3df1 = pd.DataFrame( 4 [["a1","L1"], 5 ["a2","L1"], 6 ["a3","L1"], 7 ["d1","L1"], 8 ["a4","L2"], 9 ["a5","L2"], 10 ["a6","L2"], 11 ["d2","L2"]] 12) 13 14df2 = pd.DataFrame( 15 [["d1","L1"], 16 ["d2","L2"]] 17) 18 19res =df1[df1[1].isin(df2[1]) & ~df1[0].isin(df2[0])] 20print(res) 21# 0 1 22#0 a1 L1 23#1 a2 L1 24#2 a3 L1 25#4 a4 L2 26#5 a5 L2 27#6 a6 L2

投稿2018/07/20 00:06

magichan

総合スコア15898

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

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

yanyan1010

2018/07/20 04:09

ありがとうございます、こういう書き方ができるんですね。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問