【Python】引数に型指定をする方法
公開: 更新:Pythonの関数で引数の型指定を行う方法
Pythonでは関数の引数に型ヒントを指定することで、コードの可読性を高め意図を明確にできます。型ヒントは引数名の後にコロン (:) を付けて記述します。
型ヒントはあくまで「ヒント」であり、Pythonの動的型付けの性質を変えるものではないため、型が一致しない場合でも「実行時にエラーにならない」ことに注意が必要です。しかし、型ヒントを使用することで静的解析ツール(mypyなど)やIDEのサポートが向上し、バグの早期発見や開発効率の向上が期待できます。
また、型ヒントはPython 3.5以降で導入された機能であるため、古いバージョンのPythonでは利用できない点に注意してください。
【サンプルコード】
def add(a: int, b: int) -> int:
return a + b
result = add(3, 5)
print(result)
【実行結果】
8
上記のコードでは引数aとbが整数型 (int) であること、戻り値も整数型であることを明示しています。-> int の部分は戻り値の型アノテーションと呼ばれ、関数の戻り値の型を示します。
【PR】プログラミングや生成AIを無料で学べる「コードキャンプフリー」
引数にデフォルト値を設定し型指定を行う方法
Pythonでは引数にデフォルト値を設定でき、さらに型ヒントを追加できます。型ヒントを追加できることによって、デフォルト値を持つ引数の型が明確になります。基本的な構文は通常の引数の型指定と同じですが、デフォルト値は型ヒントの後に = で記述する必要があります。
【サンプルコード】
def greet(name: str = "Guest") -> str:
return f"Hello, {name}!"
print(greet())
print(greet("Alice"))
【実行結果】
Hello, Guest!
Hello, Alice!
上記のコードでは、引数nameが文字列型 (str) であることが明示されており、デフォルト値として"Guest"が設定されています。この設定により引数が省略された場合でも、関数が文字列型の引数を期待していることが保証されます。
デフォルト値を持つ引数は型ヒントを省略することも可能ですが、型ヒントを記述することでコードの可読性と保守性が向上することを覚えておくと良いでしょう。。
Pythonで可変長引数に型指定を行う方法
複数の引数を受け取る場合、可変長引数 (*args) やキーワード可変長引数 (**kwargs) にも型ヒントを指定できます。可変長引数の場合はtypingモジュールのTupleを、キーワード可変長引数の場合はDictを使用することが一般的です。
【サンプルコード】
from typing import Tuple, Dict
def sum_numbers(*numbers: Tuple[int, ...]) -> int:
return sum(numbers)
def describe_person(**details: Dict[str, str]) -> None:
for key, value in details.items():
print(f"{key}: {value}")
result = sum_numbers(1, 2, 3, 4)
print(result)
describe_person(name="Alice", age="30", city="New York")
【実行結果】
10
name: Alice
age: 30
city: New York
sum_numbers関数だと*numbersは整数のタプル (Tuple[int, ...]) として扱われ、Tuple[int, ...]と記述することでタプル内の要素が全て整数型であることを示します。
キーワード可変長引数のdescribe_person関数では、**details が文字列をキーとし、文字列を値とする辞書型(Dict[str, str])として扱われることを示しています。このように可変長引数に型ヒントを追加することで、関数がどのような入力を受け取るかを明確にすることが可能です。
また、*args は任意の数の位置引数をタプルとして受け取り、**kwargs は任意の数のキーワード引数を辞書として受け取ります。
※上記コンテンツの内容やソースコードはAIで確認・デバッグしておりますが、間違いやエラー、脆弱性などがある場合は、コメントよりご報告いただけますと幸いです。
ITやプログラミングに関するコラム
【Python】仮想環境から抜ける方法
【Python】文字列から改行コードを除去する方法
【Python】10回の繰り返し処理を実装する方法
【Python】df(DataFrame)とは?基本的な使い方やデータ操作について解説
【Python】指定のファイルがあれば削除する方法
ITやプログラミングに関するニュース
Azure SQL Managed InstanceがVector型Public Preview対応開始、AI駆動アプリケーション開発の効率化を実現
GoogleがGmailアプリにGeminiサマリーカードを導入、メール要約の自動表示機能が利用可能に
ZenchordとNottaが共同開発したAIイヤホンZenchord 1をMakuakeで先行公開、音声認識から議事録作成まで自動化
Ideinが音声解析AIサービス「Phonoscape」の提供を開始、対面接客現場での会話データ活用が可能に
Microsoftが.NET 10 Preview 4でdotnet run app.cs機能をリリース、プロジェクトファイル不要でC#実行が可能に

