[解決!Python]Python処理系のバージョンを確認するには解決!Python

sysモジュールとplatformモジュールが提供する属性や関数、あるいはpythonコマンドを使ってPython処理系のバージョンを確認する方法を紹介する。

» 2021年11月30日 05時00分 公開
[かわさきしんじDeep Insider編集部]

この記事は会員限定です。会員登録(無料)すると全てご覧いただけます。

「解決!Python」のインデックス

連載目次

スクリプトでのバージョンの確認

# sysモジュールのversion属性とversion_info属性
import sys

sysver = sys.version
print(sysver)
# 出力例:
#3.10.0 (tags/v3.10.0:b494f59, Oct  4 2021, 19:00:18) [MSC v.1929 64 bit (AMD64)]
#3.10.0 (v3.10.0:b494f5935c, Oct  4 2021, 14:59:20) [Clang 12.0.5 (clang-1205.0.22.11)]

sysverinfo = sys.version_info
print(sysverinfo)
# 出力例:
#sys.version_info(major=3, minor=10, micro=0, releaselevel='final', serial=0)

major = sysverinfo.major  # sysverinfo[0]と同値
minor = sysverinfo.minor  # sysverinfo[1]と同値
micro = sysverinfo.micro  # sysverinfo[2]と同値
print(f'Python {major}.{minor}.{micro}'# Python 3.10.0

# platformモジュールのpython_version関数とpython_version_tuple関数
import platform

pltpyver = platform.python_version()
print(pltpyver)  # 3.10.0

t = platform.python_version_tuple()
print(t)  # ('3', '10', '0')
print(f'Python {t[0]}.{t[1]}.{t[2]}'# Python 3.10.0


pythonコマンドでのバージョンの確認

% python3 --version
Python 3.10.0
% python3 -V
Python 3.10.0
% python3 -VV
Python 3.10.0 (v3.10.0:b494f5935c, Oct  4 2021, 14:59:20) [Clang 12.0.5
(clang-1205.0.22.11)]



sysモジュールのversion属性とversion_info属性

 sysモジュールとplatformモジュールには、Pythonプログラムからそれを実行しているPython処理系のバージョンを確認するのに利用できる属性や関数が幾つか含まれている。

 sysモジュールではversion属性とversion_info属性がこうした目的に使用できる。

 以下はsys.version属性を使用する例だ。

import sys

sysver = sys.version
print(sysver)
# 出力例:
#3.10.0 (tags/v3.10.0:b494f59, Oct  4 2021, 19:00:18) [MSC v.1929 64 bit (AMD64)]
#3.10.0 (v3.10.0:b494f5935c, Oct  4 2021, 14:59:20) [Clang 12.0.5 (clang-1205.0.22.11)]


 ご覧の通り、sys.version属性はPython処理系のバージョン、ビルド番号やビルドに使われたコンパイラに関する情報などを含んだ文字列である。

 sys.version_info属性の使用例を以下に示す。

sysverinfo = sys.version_info
print(sysverinfo)
# 出力例:
#sys.version_info(major=3, minor=10, micro=0, releaselevel='final', serial=0)


 上に示すように、sys.version_info属性は5要素で構成される名前付きタプルである。そのうち、releaselevelだけが文字列で他の要素は全て整数値となる。また、これは名前付きタプルなので、以下のように(インデックスではなく)属性のように各要素にアクセスすることも可能だ。

major = sysverinfo.major  # sysverinfo[0]と同値
minor = sysverinfo.minor  # sysverinfo[1]と同値
micro = sysverinfo.micro  # sysverinfo[2]と同値
print(f'Python {major}.{minor}.{micro}'# Python 3.10.0


 プログラムの動作を特定のバージョン以降のみに制限する場合などには、こちらを使うのがよいかもしれない。特に2021年現在、Pythonはマイナーバージョンが2桁となっている。文字列にしろ数値にしろ、3.10と3.9なら後者が大きくなるので安易に「メジャーバージョン.マイナーバージョン」を条件とすると想定とは異なる動作をする可能性がある。以下はバージョンを比較してPython 3.10以降のみをサポートしようとしているつもりのコード例だが、2つ目の例では例外が発生してしまう。

if major != 3 or minor <= 9# Python 3.10以降を想定(Python 4がないこと前提)
    raise RuntimeError('Python version does not meet to run this program.')

sysver = sysver.split(' ')[0# Pythonバージョンだけを抽出
print(sysver)  # 3.10.0
if sysver <= '3.9'# '3.10.0' <= '3.9'なので例外が発生する
    raise RuntimeError('Python version does not meet to run this program.')


platformモジュールのpython_version関数とpython_version_tuple関数

 platformモジュールにもPythonのバージョンやビルドに関する情報を取得するさまざまな関数がある。

関数 説明
python_version関数 Pythonのバージョンを表す文字列を返す
python_version_tuple関数 Pythonのバージョンを表すタプルを返す
python_build関数 処理系のビルド番号と日付を返す
python_compiler関数 処理系のビルドに使用したコンパイラの情報を返す
python_branch関数 バージョン管理システムにおけるその処理系のブランチを返す
python_implementation関数 実装の種類('CPython'など)を返す
python_revision関数 バージョン管理システムに置けるその処理系のリビジョンを返す
platformモジュールが提供する関数(一部)

 ここではpython_version関数とpython_version_tuple関数を紹介する。

 platform.python_version関数はPythonのバージョンを表す文字列を返す。以下に例を示す。

import platform

pltpyver = platform.python_version()
print(pltpyver)  # 3.10.0


 一方、platform.python_version_tuple関数はPythonのメジャーバージョン、マイナーバージョン、パッチレベルを表す文字列を要素とするタプルを返す。以下に例を示す。

t = platform.python_version_tuple()
print(t)  # ('3', '10', '0')
print(f'Python {t[0]}.{t[1]}.{t[2]}'# Python 3.10.0


pythonコマンドを使ってバージョンを確認する

 Pythonのバージョンは、pythonコマンドに以下のオプションを渡すことでも確認できる。

  • --version:バージョン番号を表示(「Python 3.10.0」など)
  • -V:バージョン番号を表示(上と同じ)
  • -VV:バージョン番号と詳細な情報を表示(上記に加え、platform.python_revision関数で得られるリビジョン番号や、ビルドの日付、ビルドに使用した処理系などの情報が表示される)

 以下に例を示す。

% python3 --version
Python 3.10.0
% python3 -V
Python 3.10.0
% python3 -VV
Python 3.10.0 (v3.10.0:b494f5935c, Oct  4 2021, 14:59:20) [Clang 12.0.5
(clang-1205.0.22.11)]



「解決!Python」のインデックス

解決!Python

Copyright© Digital Advantage Corp. All Rights Reserved.

スポンサーからのお知らせPR

注目のテーマ

Microsoft & Windows最前線2025
AI for エンジニアリング
ローコード/ノーコード セントラル by @IT - ITエンジニアがビジネスの中心で活躍する組織へ
Cloud Native Central by @IT - スケーラブルな能力を組織に
システム開発ノウハウ 【発注ナビ】PR
あなたにおすすめの記事PR

RSSについて

アイティメディアIDについて

メールマガジン登録

@ITのメールマガジンは、 もちろん、すべて無料です。ぜひメールマガジンをご購読ください。