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?

More than 1 year has passed since last update.

PythonのType Hint(annotation)を自由自在に操る

Last updated at Posted at 2022-05-04

PythonのType Hintを使ってますか?
最初は苦痛でしか無かったのですが、最近、意図通り使えるようになってきた。

Type Hint使う理由(利点)

  1. 実行前にエラーがわかり、時間節約
  2. 思い違いの論理エラーを早くに検出し、時間無駄にしない。
  3. 改てコード見直した時、コード内容を思い起こしやすい。

Type Hintという結論は良さそう

  1. 型厳密性が高い言語の方がコンパイルした時の早いじゃないの?、と思ってますし、きっとそうでしょう。ただし、静的型付に比べ、型のstrict性が無がないのでPythonicな書き方を維持できていると思う。
  2. annotationのおかげで、Cythonの型指定も楽になりました。(Pure Pythonモードなので20-50%の向上しか無いそうですが。)
# CythonのAnnonationを使った例
@cython.cdef
def main(a:cython.int):
   ...

Type Hintが誤解する箇所の対処方法

書きかけです。優先度が高い情報から記載

可読性が高い書き方へ移行

  1. 古いPythonを使わないといけない時に便利。下記おまじないを書くとPy3.9以降の記法が適用されるみたい
  2. from __future__ import annotations

例えば、

  1. typing.Union[int,float]int|floatと書ける
  2. typing.List[int]list[int]とかける

SQLAlchemyの場合

SQLAlchemyのobjの型補完

下記でうまくいく?エラーで解析できてないだけ?

  • 自動解決されてないので、型を記す。
  • 例: registration_datetime:datetime.datetime= Column(DateTime)
  • SQLAlchemyはstubがあるけど効かない。どう使うのだろう...import?
  • sessionやengineのTypeHint。これをするとPyCharmでは、メソッド候補がホバーされる。
connection_string: str = "sqlite:///:memory:"
engine = create_engine(connection_string)
session = Session(bind=engine)
print(type(engine))   # sqlalchemy.engine.base.Engine
print(type(session))  # sqlalchemy.orm.session.Session

SQLAlchemyのデータ型に対するTypeHintの書き方。

reg_dtt: sqlalchemy.Mapped[datetime.datetime] = sa.Column(sa.DateTime, nullable=False)

上記の通りMappedで型指定すると、下記通りbetweenでMyPy由来のエラーでない。確認PyCharm2021.1.MyPy0.951.

MyTable.reg_dtt.between(start, end))

Noneから初期化されている事を示す / 型が適切である事を示す。

  • assertと併用する
  • assert 変数 is not None, "変数は初期化されてない"

castを使う

mypyは異なるvenvの物を利用しない

  1. 結果が正確でなくなるから。おそらく、同venvのパッケージを解析する方が正確なのだろう。
  2. PyCharmで、高速化を期待してmypyをdaemonとして登録したが、異なるvenvのmypyでは正確ではない事に気づいた。

stub/typesパッケージのインスト

  1. これらパッケージを入れると、型やら記述された.pyiファイルがインストールされて、IDEなどで型情報が補完されるらしい
    1. wearepal/data-science-types
      • Mypy type stubs for NumPy, pandas, and Matplotlib
    2. sqlalchemy-stub
      2. どちらを使う方がいいのかなsqlalchemy2-stubs

enum.auto

下記で上手くいく?

  1. var : Enum型Class名|str
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?