0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

Pythonでのオプショナル型の使い方とスクレイピングの実装

Posted at

はじめに

Pythonでは、オプショナル型(Optional)を用いることで、関数やメソッドが値を返す or 返さないといったケースを安全に扱うことができます。
スクレイピングのようなデータ取得処理では、取得できるデータが不確定な場合もあります。
そのような場合、オプショナル型を使うとコードの安全性と可読性が向上します。

オプショナル型とは

Pythonの標準ライブラリ typing モジュールには、Optional 型が用意されています。
Optional は、「値があるかもしれないし、None かもしれない」ことを示すための型です。

使用例

Optional は次のように使用します:

from typing import Optional

def get_username(user_id: int) -> Optional[str]:
    if user_id == 1:
        return "JohnDoe"
    else:
        return None

# 使用例
username = get_username(2)
if username is not None:
    print(f"Username: {username}")
else:
    print("User not found")

この例では、get_username 関数が文字列型 (str) もしくは None を返すことがわかります。
関数の戻り値が None である可能性を型として明示することで、開発者は None チェックを忘れずに行うことができます。

スクレイピングにおけるオプショナル型の利用

スクレイピングを行う際には、ページから特定の要素を取得することが目的となりますが、要素が存在しない場合も考慮する必要があります。
ここで Optional を利用することで、コードの安全性を高めることができます。

以下の例では、requestsBeautifulSoup を用いて、Webページからタイトルを取得する簡単なスクレイピングを行います。

必要なライブラリのインストール

まず、requestsBeautifulSoup をインストールしていない場合はインストールします:

bash
pip install requests beautifulsoup4

サンプルコード

python
import requests
from bs4 import BeautifulSoup
from typing import Optional

def fetch_page(url: str) -> Optional[str]:
    """指定したURLからページのHTMLを取得する関数"""
    try:
        response = requests.get(url)
        response.raise_for_status()  # ステータスコードがエラーの場合は例外を発生させる
        return response.text
    except requests.RequestException as e:
        print(f"Error fetching the URL: {e}")
        return None

def get_title(html: Optional[str]) -> Optional[str]:
    """HTMLからタイトルを取得する関数"""
    if html is None:
        return None

    soup = BeautifulSoup(html, 'html.parser')
    title_tag = soup.find('title')
    return title_tag.get_text(strip=True) if title_tag else None

if __name__ == "__main__":
    url = "https://example.com"
    html = fetch_page(url)
    title = get_title(html)

    if title:
        print(f"Page Title: {title}")
    else:
        print("Title not found or failed to fetch page.")

コードの説明

  1. fetch_page 関数: 指定されたURLからHTMLを取得します。requestsを使ってHTTPリクエストを行い、成功した場合はページの内容を文字列として返します。
    リクエストに失敗した場合は None を返します。この関数の戻り値は Optional[str] 型です。

  2. get_title 関数: HTML文字列を受け取り、BeautifulSoupを使ってページのタイトルを取得します。
    HTMLが None の場合や、タイトルタグが見つからない場合は None を返します。
    この関数の戻り値も Optional[str] 型です。

  3. if __name__ == "__main__": ブロック: 実際のスクレイピングの実行部分です。
    URLを指定してページのタイトルを取得し、結果に応じて適切なメッセージを表示します。

なぜオプショナル型を使うのか?

このスクレイピングの実装では、オプショナル型を使用することで、次の利点があります:

  • エラー処理が簡潔になる: 関数が None を返す可能性を明示することで、呼び出し側で必ず None チェックを行うように促します。
  • コードの可読性が向上する: 戻り値の型が明示されているため、他の開発者がコードを読む際に関数の意図を理解しやすくなります。
  • 型ヒントによる開発支援: IDEやエディタが型チェックを行ってくれるため、実装ミスを早期に発見できます。

まとめ

Pythonのオプショナル型(Optional)を使うことで、スクレイピングのようなデータの有無が不確定な状況でのプログラムの安全性を向上させることができます。

Webからのデータ取得処理では、存在しない要素や取得エラーに対処するために、オプショナル型を活用して例外的なケースを効果的に扱えます。

0
0
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
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?