LoginSignup
6
8

More than 3 years have passed since last update.

SQLのLIKE句を、pandas(python)のqueryメソッドのstr.contains()を使って合致するデータ抽出を行って見た

Last updated at Posted at 2020-10-24

はじめに

 最近、プライベートでデータ分析のツールを作成している関係でpandasというpython外部ライブラリを活用している。が、いざ使って見ると、「pandas?なにそれかわいいの?」と動物のパンダ🐼を連想させるヤバい思考に行きつつある状況になる。
 これはまずいと感じ、投稿者はpandasを探し求める旅に出る。
 この記事は、pandasを飼いならすためにpandasをSQLっぽく考えるというデータサイエンス初学者に向けた記事となります。

そもそもpandasとは何か

 pandasとは、構造化された(表形式、多次元、潜在的に不均質)データと時系列データを簡単かつ直感的に操作できるように設計された高速で柔軟な表現力のあるデータ構造を提供するPythonパッケージで、実際的な実世界のデータ分析を行うための基本的な高レベルのビルドを行う事が可能なツールです。
 要は、表データをpythonを使っていい感じに処理して目的のデータ抽出するツールです。

実践

準備

今回は下記の表データ【store】を用いてpandas攻略を行います。(表データはCSV形式)

image.png

※データは長いので冒頭部分のみ表示

参考データ:データサイエンス100本ノック
https://github.com/The-Japan-DataScientist-Society/100knocks-preprocess

また、今回はpandasを使用するため、コードは下記のように予め準備しておきます。

python
import pandas as pd
df_store = pd.read_sql('storeのCSVファイルのパス', sep=',')

本題

タイトルにある通り、今回はSQLのLIKE句をpandasを使って再現します


問題:店舗データフレーム(df_store)から横浜市の店舗(address)だけ全項目表示せよ。

目的:条件に一致する対象行のデータ抽出する事

解答

解答を記述するとこんな感じになります。

pandas(python)
df_store.query("address.str.contains('横浜市')", engine='python')

そして、図に表すとこんな感じになります。

image.png

これをSQL文で表すとこんな感じになります。

SQL
select * from store where address LIKE '%横浜市%';

解説

それでは、ここから解説していきます。

  • pandasのqueryメソッドを活用する
    まず、pandasのqueryメソッドを用いてSQLに当たるWHERE文を定義します

※補足:pandasのqueryメソッドに関する詳細の記事は下記を参考にしてみて下さい。
https://qiita.com/syuki-read/items/9a57b78f6a577c2fbefe

形式を表現するとこんな感じです。

pandas(python)
df_store.query('指定したい条件内容')

これをSQLで考えると、こんな感じになります。

SQL
select * from store where '条件内容';

FROM句:データベース内の指定する表を選択する
SELECT文:指定した表から抽出すべき列を選択する

  • SQLのLIKE句を、str.contains()で表現する
    そしてここから、pandasのqueryメソッドのstr.contains()を用いて、(SQLのLIKE句のように)対象の列(address)から条件に合致するカラムの選択を行います。str.contains()の内容を説明すると、これは()内に含まれる文字列を抽出する事を意味します。

実際に書いてみるとこんな感じになります。

pandas(python)
df_store.query("address.str.contains('横浜市')", engine='python')

ここでは、storeテーブルのaddress列の文字列の中に「横浜市」が含まれているカラムを抽出するという事を指します。また、後ろに書いてある「engine='python'」は文字列型(str型)のメソッドではお約束事して、必要となるためこちらも忘れずに付ける事に注意しましょう。

これをSQLで考えるとこんな感じになります。

SQL
select * from store where address LIKE '%横浜市%';

そして、図を表すとこんな感じになります。

image.png

  • 全体図
    全体をまとめると、こんな感じになります。

image.png

コラム

今回はstr.contains()でデータ抽出を行いましたが、文字列(str型)のデータ抽出は他にもこんなのあったりします。

  • str.contains(): 特定の文字列を含む
  • str.endswith(): 特定の文字列で終わる
  • str.startswith(): 特定の文字列で始まる
  • str.match(): 正規表現のパターンに一致する

データ抽出は状況によって変化するため、柔軟に使い分けていく事が大事です。

まとめ

今回はpandasを使って、SQLのLIKE句の表現を行いました。pandasはデータベース及びSQLを意識したpythonライブラリなため、普段からSQLを意識するとかなり使いやすいツールだと改めて感じます。また、特定の命令文を指示する時、SQLがいくつものパターンがあるように、pandasにも多様なパターンが存在すると、pandasを活用して日々実感を持ちます。

終わりに

 今回、利活用したデータはデータサイエンス協会(DS協会)の「データサイエンス100本ノック」を参考にしております。こちらはJupyter notebookを使用しているので、より見やすいデータが抽出されます。
 この記事を読んで、「実際に実装してみたい!!」という方がおりましたら、下記にその実装に関する記事を上げているので、良かったそちらの記事を参考に是非実装してみて下さい。

データサイエンス初学者にむけた、データサイエンス100本ノックを実装する方法:
https://qiita.com/syuki-read/items/714fe66bf5c16b8a7407

6
8
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
6
8