28.1. sys
— システムパラメータと関数¶
このモジュールでは、インタプリタで使用・管理している変数や、インタプリタの動作に深く関連する関数を定義しています。このモジュールは常に利用可能です。
-
sys.
argv
¶ Pythonスクリプトに渡されたコマンドライン引数のリスト。
argv[0]
はスクリプトの名前となりますが、フルパス名かどうかは、OSによって異なります。コマンドライン引数に-c
を付けて Pythonを起動した場合、argv[0]
は文字列'-c'
となります。スクリプト名なしでPythonを起動した場合、argv[0]
は空文字列になります。標準入力もしくはコマンドライン引数で指定されたファイルのリストに渡ってループするには、
fileinput
モジュールを参照してください。
-
sys.
byteorder
¶ プラットフォームのバイト順を示します。ビッグエンディアン (最上位バイトが先頭) のプラットフォームでは
'big'
, リトルエンディアン (最下位バイトが先頭) では'little'
となります。バージョン 2.0 で追加.
-
sys.
builtin_module_names
¶ コンパイル時にPythonインタプリタに組み込まれた、全てのモジュール名のタプル(この情報は、他の手段では取得することができません。
modules.keys()
は、インポートされたモジュールのみのリストを返します。)
-
sys.
call_tracing
(func, args)¶ トレーシングが有効な間、
func(*args)
を呼び出します。トレーシングの状態は保存され、後で復元されます。これは、別のコードをチェックポイントから再帰的にデバッグするために、デバッガから呼び出されることを意図しています。
-
sys.
copyright
¶ Python インタプリタの著作権を表示する文字列です。
-
sys.
_clear_type_cache
()¶ 内部の型キャッシュをクリアします。型キャッシュは属性とメソッドの検索を高速化するために利用されます。この関数は、参照リークをデバッグするときに不要な参照を削除するため だけ に利用してください。
この関数は、内部的かつ特殊な目的にのみ利用されるべきです。
バージョン 2.6 で追加.
-
sys.
_current_frames
()¶ 各スレッドの識別子を関数が呼ばれた時点のそのスレッドでアクティブになっている一番上のスタックフレームに結びつける辞書を返します。モジュール
traceback
の関数を使えばそのように与えられたフレームのコールスタックを構築できます。この関数はデッドロックをデバッグするのに非常に有効です。デッドロック状態のスレッドの協調動作を必要としませんし、そういったスレッドのコールスタックはデッドロックである限りフリーズしたままです。デッドロックにないスレッドのフレームについては、そのフレームを調べるコードを呼んだ時にはそのスレッドの現在の実行状況とは関係ないところを指し示しているかもしれません。
この関数は、内部的かつ特殊な目的にのみ利用されるべきです。
バージョン 2.5 で追加.
-
sys.
dllhandle
¶ Python DLLのハンドルを示す整数です。利用できる環境: Windows。
-
sys.
displayhook
(value)¶ value が
None
以外の場合、value
をsys.stdout
に出力して__builtin__._
に保存します。sys.displayhook
は、Pythonの対話セッションで入力された式(expression)が評価されたときに呼び出されます。対話セッションの出力をカスタマイズする場合、sys.displayhook
に引数の数が一つの関数を指定します。
-
sys.
dont_write_bytecode
¶ この値が真の時、Python はソースモジュールをインポートする時に
.pyc
や.pyo
ファイルを生成しません。この値は-B
コマンドラインオプションとPYTHONDONTWRITEBYTECODE
環境変数の値によって起動時にTrue
かFalse
に設定されます。しかし、実行時にこの変数を変更して、バイトコード生成を制御することもできます。バージョン 2.6 で追加.
-
sys.
excepthook
(type, value, traceback)¶ 指定したトレースバックと例外を
sys.stderr
に出力します。例外が発生し、その例外が捕捉されない場合、インタプリタは例外クラス・例外インスタンス・トレースバックオブジェクトを引数として
sys.excepthook
を呼び出します。対話セッション中に発生した場合はプロンプトに戻る直前に呼び出され、Pythonプログラムの実行中に発生した場合はプログラムの終了直前に呼び出されます。このトップレベルでの例外情報出力処理をカスタマイズする場合、sys.excepthook
に引数の数が三つの関数を指定します。
-
sys.
__displayhook__
¶ -
sys.
__excepthook__
¶ それぞれ、起動時の
displayhook
とexcepthook
の値を保存しています。この値は、displayhook
とexcepthook
に不正なオブジェクトが指定された場合に、元の値に復旧するために使用します。
-
sys.
exc_info
()¶ この関数は、現在処理中の例外を示す三つの値のタプルを返します。この値は、現在のスレッド・現在のスタックフレームのものです。現在のスタックフレームが例外処理中でない場合、例外処理中のスタックフレームが見つかるまで次々とその呼び出し元スタックフレームを調べます。ここで、"例外処理中" とは "except 節を実行中、または実行した" フレームを指します。どのスタックフレームでも、最後に処理した例外の情報のみを参照することができます。
スタック上で例外が発生していない場合、三つの
None
のタプルを返します。例外が発生している場合、(type, value, traceback)
を返します。 type は、処理中の例外の型を示します (クラスオブジェクト)。 value は、例外パラメータ (例外に 関連する値 またはraise
の第二引数。 type がクラスオブジェクトの場合は常にクラスインスタンス) です。 traceback は、トレースバックオブジェクトで、例外が発生した時点でのコールスタックをカプセル化したオブジェクトです(リファレンスマニュアル参照)。exc_clear()
が呼び出されると、現在のスレッドで他の例外が発生するか、又は別の例外を処理中のフレームに実行スタックが復帰するまで、exc_info()
は三つのNone
を返します。警告
例外処理中に戻り値の traceback をローカル変数に代入すると循環参照が発生し、関数内のローカル変数やトレースバックが参照している全てのオブジェクトは解放されなくなります。特にトレースバック情報が必要ではなければ
exctype, value = sys.exc_info()[:2]
のように例外型と例外オブジェクトのみを取得するようにして下さい。もしトレースバックが必要な場合には、処理終了後にdeleteして下さい。このdeleteは、try
…finally
…で行うと良いでしょう。注釈
Python 2.2 以降では、ガベージコレクションが有効であればこのような到達不能オブジェクトは自動的に削除されます。しかし、循環参照を作らないようにしたほうが効率的です。
-
sys.
exc_clear
()¶ この関数は、現在のスレッドで処理中、又は最後に発生した例外の情報を全てクリアします。この関数を呼び出すと、現在のスレッドで他の例外が発生するか、又は別の例外を処理中のフレームに実行スタックが復帰するまで、
exc_info()
は三つのNone
を返します。この関数が必要となることは滅多にありません。ロギングやエラー処理などで最後に発生したエラーの報告を行う場合などに使用します。また、リソースを解放してオブジェクトの終了処理を起動するために使用することもできますが、オブジェクトが実際にされるかどうかは保障の限りではありません。
バージョン 2.3 で追加.
-
sys.
exc_type
¶ -
sys.
exc_value
¶ -
sys.
exc_traceback
¶ バージョン 1.5 で撤廃:
exc_info()
を使用してくださいこれらの変数はグローバル変数なのでスレッド毎の情報を示すことができません。この為、マルチスレッドなプログラムでは安全に参照することはできません。例外処理中でない場合、
exc_type
の値はNone
となり、exc_value
とexc_traceback
は未定義となります。
-
sys.
exec_prefix
¶ Python のプラットフォーム依存なファイルがインストールされているディレクトリ名(サイト固有)。デフォルトでは、この値は
'/usr/local'
ですが、ビルド時に configure の--exec-prefix
引数で指定することができます。全ての設定ファイル(pyconfig.h
など)はexec_prefix/lib/pythonX.Y/config
に、共有ライブラリはexec_prefix/lib/pythonX.Y/lib-dynload
にインストールされます。 X.Y は Python のバージョン番号で、例えば2.7
です。
-
sys.
executable
¶ Python インタプリタの実行ファイルの絶対パスを示す文字列です。このような名前が意味を持つシステムで利用可能です。Python が自身の実行ファイルの実際のパスを取得できない場合、
sys.executable
は空の文字列またはNone
になります。
-
sys.
exit
([arg])¶ Python を終了します。
exit()
はSystemExit
を送出するので、try
ステートメントのfinally
節に終了処理を記述したり、上位レベルで例外を捕捉して exit 処理を中断したりすることができます。オプション引数 arg には、終了ステータスとして整数 (デフォルトは0) や他の型のオブジェクトを指定することができます。整数を指定した場合、シェル等は 0 は "正常終了"、0 以外の整数を "異常終了" として扱います。多くのシステムでは、有効な終了ステータスは 0–127 で、これ以外の値を返した場合の動作は未定義です。システムによっては特定の終了コードに個別の意味を持たせている場合がありますが、このような定義は僅かしかありません。Unix プログラムでは構文エラーの場合には 2 を、それ以外のエラーならば 1 を返します。arg に
None
を指定した場合は、数値の 0 を指定した場合と同じです。それ以外の型のオブジェクトを指定すると、そのオブェクトがstderr
に出力され、終了コードとして 1 を返します。エラー発生時にはsys.exit("エラーメッセージ")
と書くと、簡単にプログラムを終了することができます。究極には、
exit()
は例外を送出する "だけ" なので、これがメインスレッドから呼び出されたときは、プロセスを終了するだけで、例外は遮断されません。
-
sys.
exitfunc
¶ この値はモジュールに存在しませんが、ユーザプログラムでプログラム終了時に呼び出される終了処理関数として、引数の数が 0 の関数を設定することができます。この関数は、インタプリタ終了時に呼び出されます。
exitfunc
に指定することができる終了処理関数は一つだけですので、複数のクリーンアップ処理が必要な場合はatexit
モジュールを使用してください。注釈
プログラムがシグナルで kill された場合、 Python 内部で致命的なエラーが発生した場合、
os._exit()
が呼び出された場合には、終了処理関数は呼び出されません。バージョン 2.4 で撤廃:
atexit
を使ってください。
-
sys.
flags
¶ 属性とシーケンスを利用して、コマンドラインフラグの状態を提供しています。属性は読み込み専用になっています。
属性 フラグ debug
-d
py3k_warning
-3
division_warning
-Q
division_new
-Qnew
inspect
-i
interactive
-i
optimize
-O
または-OO
dont_write_bytecode
-B
no_user_site
-s
no_site
-S
ignore_environment
-E
tabcheck
-t
または-tt
verbose
-v
unicode
-U
bytes_warning
-b
hash_randomization
-R
バージョン 2.6 で追加.
バージョン 2.7.3 で追加:
hash_randomization
属性が追加されました。
-
sys.
float_info
¶ 属性とシーケンスを利用して、 float 型に関する情報を提供します。精度と内部表現に関する情報を含みます。プログラミング言語 'C' の標準ヘッダファイル
float.h
に定義された様々な浮動小数点定数に対応する値の詳細については、1999 ISO/IEC C standard [C99] の 4.2.4.2.2 章を参照して下さい。属性 float.h のマクロ 説明 epsilon
DBL_EPSILON 1と、その次の表現可能なfloat値の差 dig
DBL_DIG 浮動小数点数で正確に表示できる最大の10進数桁; 以下参照 mant_dig
DBL_MANT_DIG 浮動小数点精度: 浮動小数点数の主要部の桁 base- radix
max
DBL_MAX floatが表せる最大の(infiniteではない)値 max_exp
DBL_MAX_EXP floatが radix**(e-1)
で表現可能な、最大の整数 emax_10_exp
DBL_MAX_10_EXP float が 10**e
で表現可能な、最大の整数 emin
DBL_MIN float が表現可能な最小の正の値 min_exp
DBL_MIN_EXP radix**(e-1)
が正規化floatであるような最小の整数 emin_10_exp
DBL_MIN_10_EXP 10**e
が正規化floatであるような最小の整数 eradix
FLT_RADIX 指数部の基数 rounds
FLT_ROUNDS 算術演算で利用される丸めモードを表す整数定数。これはインタプリタ起動時のシステムの FLT_ROUNDS マクロの値を示します。取りうる値とその意味については、C99 標準の 5.2.4.2.2 節を参照してください。 sys.float_info.dig
に対してはさらに説明が必要です。もし、文字列s
が表す 10 進数の有効桁数が多くてもsys.float_info.dig
の時には、s
を浮動小数点数に変換して戻すと同じ 10 進数を表す文字列に復元されます:>>> import sys >>> sys.float_info.dig 15 >>> s = '3.14159265358979' # decimal string with 15 significant digits >>> format(float(s), '.15g') # convert to float and back -> same value '3.14159265358979'
ただし、文字列が有効桁数
sys.float_info.dig
より大きい場合には、常に復元されるとは限りません:>>> s = '9876543211234567' # 16 significant digits is too many! >>> format(float(s), '.16g') # conversion changes value '9876543211234568'
バージョン 2.6 で追加.
-
sys.
float_repr_style
¶ repr()
関数が浮動小数点数に対してどう振る舞うかを指し示す文字列です。この文字列が値'short'
を持てば、有限の浮動小数点数x
に対して、repr(x)
はfloat(repr(x)) == x
を満たす短い文字列を返そうとします。これは、 Python 2.7 以降での標準の振る舞いです。そうでなければ、float_repr_style
は値'legacy'
を持ち、repr(x)
は 2.7 以前のバージョンの Python と同じように振る舞います。バージョン 2.7 で追加.
-
sys.
getcheckinterval
()¶ インタプリタの "チェックインターバル (check interval)" を返します;
setcheckinterval()
を参照してください。バージョン 2.3 で追加.
-
sys.
getdefaultencoding
()¶ Unicode 実装で使用される現在のデフォルトエンコーディング名を返します。
バージョン 2.0 で追加.
-
sys.
getfilesystemencoding
()¶ Unicode ファイル名をシステムのファイル名に変換する際に使用するエンコード名を返します。システムのデフォルトエンコーディングを使用する場合には
None
を返します。- Mac OS X では、エンコーディングは
'utf-8'
となります。 - Unix では、エンコーディングは
nl_langinfo(CODESET)
が返すユーザの設定となります。nl_langinfo(CODESET)
が失敗するとNone
を返します。 - Windows NT+ では、Unicode をファイル名として使用できるので変換の必要はありません。
getfilesystemencoding()
は'mbcs'
を返しますが、これはある Unicode 文字列をバイト文字列に明示的に変換して、ファイル名として使うと同じファイルを指すようにしたい場合に、アプリケーションが使わなければならないエンコーディングです。 - Windows 9x では、エンコーディングは
'mbcs'
となります。
バージョン 2.3 で追加.
- Mac OS X では、エンコーディングは
-
sys.
getrefcount
(object)¶ object の参照数を返します。 object は (一時的に)
getrefcount()
からも参照されるため、参照数は予想される数よりも 1 多くなります。
-
sys.
getrecursionlimit
()¶ 現在の最大再帰数を返します。最大再帰数は、Python インタプリタスタックの最大の深さです。この制限は Python プログラムが無限に再帰し、C スタックがオーバーフローしてクラッシュすることを防止するために設けられています。この値は
setrecursionlimit()
で指定することができます。
-
sys.
getsizeof
(object[, default])¶ object のサイズをバイト数で返します。object は任意の型のオブジェクトです。すべての組み込みオブジェクトは正しい値を返します。サードパーティー製の型については実装依存になります。
オブジェクトがサイズを取得する手段を提供していない時は default が返されます。default が指定されていない場合は
TypeError
が送出されます。getsizeof()
は object の__sizeof__
メソッドを呼び出し、そのオブジェクトがガベージコレクタに管理されていた場合はガベージコレクタのオーバーヘッドを増やします。バージョン 2.6 で追加.
-
sys.
_getframe
([depth])¶ コールスタックからフレームオブジェクトを返します。オプション引数 depth を指定すると、スタックのトップから depth だけ下のフレームオブジェクトを取得します。 depth がコールスタックよりも深ければ、
ValueError
が発生します。 depth のデフォルト値は 0 で、この場合はコールスタックのトップのフレームを返します。CPython 実装の詳細: この関数は、内部的かつ特殊な目的にのみ利用されるべきです。全ての Python 実装で存在することが保証されているわけではありません。
-
sys.
getprofile
()¶ setprofile()
関数で設定したプロファイラ関数を取得します。バージョン 2.6 で追加.
-
sys.
gettrace
()¶ settrace()
関数で設定したトレース関数を取得します。CPython 実装の詳細:
gettrace()
関数は、デバッガ、プロファイラ、カバレッジツールなどの実装に使うことのみを想定しています。この関数の振る舞いは言語定義ではなく実装プラットフォームの一部です。そのため、他の Python 実装では利用できないかもしれません。バージョン 2.6 で追加.
-
sys.
getwindowsversion
()¶ 実行中の Windows バージョンを示す、名前付きタプルを返します。名前付けされた要素は、 major, minor, build, platform, service_pack, service_pack_minor, service_pack_major, suite_mask, および product_type です。 service_pack は、文字列を含み、それ以外は整数です。この構成要素には名前でもアクセスできるので、
sys.getwindowsversion()[0]
はsys.getwindowsversion().major
と等価です。先行のバージョンとの互換性のため、最初の 5 要素がインデクシングで得られます。platform は、以下の値となります:
定数 プラットフォーム 0 (VER_PLATFORM_WIN32s)
Win32s on Windows 3.1 1 (VER_PLATFORM_WIN32_WINDOWS)
Windows 95/98/ME 2 (VER_PLATFORM_WIN32_NT)
Windows NT/2000/XP/x64 3 (VER_PLATFORM_WIN32_CE)
Windows CE product_type は、以下の値のいずれかになります。:
定数 意味 1 (VER_NT_WORKSTATION)
システムはワークステーションです。 2 (VER_NT_DOMAIN_CONTROLLER)
システムはドメインコントローラです。 3 (VER_NT_SERVER)
システムはサーバですが、ドメインコントローラではありません。 この関数は、Win32
GetVersionEx()
関数を呼び出します。これらのフィールドに関する詳細はOSVERSIONINFOEX()
についてのマイクロソフトのドキュメントを参照してください。利用出来る環境: Windows.
バージョン 2.3 で追加.
バージョン 2.7 で変更: 名前付きタプルに変更され、 service_pack_minor, service_pack_major, suite_mask, および product_type が追加されました。
-
sys.
hexversion
¶ 単精度整数にエンコードされたバージョン番号。この値は新バージョン(正規リリース以外であっても)ごとにかならず増加します。例えば、Python 1.5.2 以降でのみ動作するプログラムでは、以下のようなチェックを行います。
if sys.hexversion >= 0x010502F0: # use some advanced feature ... else: # use an alternative implementation or warn the user ...
hexversion
はhex()
で16進数に変換しなければ値の意味がわかりません。より読みやすいバージョン番号が必要な場合にはversion_info
を使用してください。hexversion
は以下のレイアウトで表される 32-bit 数です:ビット (ビッグエンディアンオーダ) 意味 1-8
PY_MAJOR_VERSION
(2.1.0a3
の2
)9-16
PY_MINOR_VERSION
(2.1.0a3
の1
)17-24
PY_MICRO_VERSION
(2.1.0a3
の0
)25-28
PY_RELEASE_LEVEL
(アルファでは0xA
、ベータでは0xB
、リリース候補では0xC
、そして最終版は0xF
)29-32
PY_RELEASE_SERIAL
(the3
in2.1.0a3
の0
、最終リリースでは 0)従って、
2.1.0a3
は hexversion で0x020100a3
です。バージョン 1.5.2 で追加.
-
sys.
long_info
¶ Python における整数の内部表現に関する情報を保持する、構造体のシーケンスです。この属性は読み込み専用です。
属性 説明 bits_per_digit
各桁に保持されるビットの数です。Python の整数は、内部的に 2**long_info.bits_per_digit
を基数として保存されます。sizeof_digit
桁を表すために使われる、C 型の大きさ (バイト) です バージョン 2.7 で追加.
-
sys.
last_type
¶ -
sys.
last_value
¶ -
sys.
last_traceback
¶ 通常は定義されておらず、捕捉されない例外が発生してインタプリタがエラーメッセージとトレースバックを出力した場合にのみ設定されます。この値は、対話セッション中にエラーが発生したとき、デバッグモジュールをロード (例:
import pdb; pdb.pm()
など。詳細は pdb — Python デバッガ を参照)して発生したエラーを調査する場合に利用します。デバッガをロードすると、プログラムを再実行せずに情報を取得することができます。変数の意味は、上の
exc_info()
の戻り値と同じです。対話セッションを実行するスレッドは常に1つだけなので、exc_type
のようにスレッドに関する問題は発生しません。
-
sys.
maxint
¶ Pythonの整数型でサポートされる、最大の整数。この値は最低でも 2**31-1 です。最大の負数は
-maxint-1
となります。正負の最大数が非対称ですが、これは 2 の補数計算を行うためです。
-
sys.
maxsize
¶ プラットフォームの Py_ssize_t 型がサポートしている最大の正の整数。したがって、リスト、文字列、辞書、その他コンテナ型の最大のサイズ。
-
sys.
maxunicode
¶ Unicode 文字の最大のコードポイントを示す整数。この値は、オプション設定で Unicode 文字の保存形式として USC-2 と UCS-4 のいずれを指定したかによって異なります。
-
sys.
meta_path
¶ finder オブジェクトのリストです。finder オブジェクトの
find_module()
メソッドは、インポートするモジュールを探すために呼び出されます。インポートするモジュールがパッケージに含まれる場合、親パッケージの__path__
属性が第 2 引数として渡されます。そのメソッドは、モジュールが見つからなかった場合はNone
を、見つかった場合は loader を返します。sys.meta_path
は、デフォルトの暗黙の finder や、sys.path
よりも先に検索されます。オリジナルの仕様については、 PEP 302 を参照してください。
-
sys.
modules
¶ ロード済みモジュールのモジュール名とモジュールオブジェクトの辞書。強制的にモジュールを再読み込みする場合などに使用します。この辞書からモジュールを削除するのは、
reload()
の呼び出しと等価では ありません 。
-
sys.
path
¶ モジュールを検索するパスを示す文字列のリスト。
PYTHONPATH
環境変数と、インストール時に指定したデフォルトパスで初期化されます。起動時に初期化された後、リストの先頭 (
path[0]
) には Python インタプリタを起動したスクリプトのあるディレクトリが挿入されます。スクリプトのディレクトリがない (インタプリタが対話セッションで起動された時や、スクリプトを標準入力から読み込んだ場合など) 場合、path[0]
は空文字列となり、Python はカレントディレクトリからモジュールの検索を開始します。スクリプトディレクトリは、PYTHONPATH
で指定したディレクトリの 前 に挿入されますので注意が必要です。必要に応じて、プログラム内で自由に変更することができます。
バージョン 2.3 で変更: Unicode 文字列が無視されなくなりました.
-
sys.
path_hooks
¶ path を引数にとって、その path に対する finder の作成を試みる呼び出し可能オブジェクトのリスト。 finder の作成に成功したら、その呼出可能オブジェクトのは finder を返します。失敗した場合は、
ImportError
を発生させます。オリジナルの仕様は PEP 302 を参照してください。
-
sys.
path_importer_cache
¶ finder オブジェクトのキャッシュとなる辞書。キーは
sys.path_hooks
に渡される path で、値は見つかった finder オブジェクト。 path が有効なファイルシステムパスであり、かつ finder がsys.path_hooks
から見つからない場合、暗黙のデフォルト finder を利用するという意味でNone
が格納されます。 path が既存のパスではない場合、imp.NullImporter
が格納されます。オリジナルの仕様は PEP 302 を参照してください。
-
sys.
platform
¶ プラットフォームを識別する文字列で、
sys.path
にプラットフォーム固有のサブディレクトリを追加する場合などに利用します。Unix システムでは、この値は
uname -s
が返す小文字のOS名を前半に、uname -r
が返すバージョン名を後半に追加したものになります。例えば、'sunos5'
や'linux2'
といった具合です。 この値はPythonをビルドした時のものです 。それ以外のシステムでは、次のような値になります。if sys.platform.startswith('freebsd'): # FreeBSD-specific code here... elif sys.platform.startswith('linux'): # Linux-specific code here...
バージョン 2.7.3 で変更: たくさんのコードが
sys.platform == 'linux2'
をチェックし、そして Linux 2.x と 3.x との間には本質的な違いもないことから、sys.platform
は Linux 3.x でさえも常に'linux2'
をセットしています。Python 3.3 とそれ以降ではこの値は常に'linux'
ですので、startswith
イディオムを常に使うことをお奨めします。その他のシステムでは以下の値になります:
システム platform
の値Linux (2.x と 3.x) 'linux2'
Windows 'win32'
Windows/Cygwin 'cygwin'
Mac OS X 'darwin'
OS/2 'os2'
OS/2 EMX 'os2emx'
RiscOS 'riscos'
AtheOS 'atheos'
参考
os.name
が持つ情報はおおざっぱな括りであり、os.uname()
はシステムに依存したバージョン情報になります。platform
モジュールはシステムの詳細な識別情報をチェックする機能を提供しています。
-
sys.
prefix
¶ Python のプラットフォームに依存しないファイルがインストールされているディレクトリ名(サイト固有)。デフォルトでは、この値は
'/usr/local'
ですが、ビルド時に configure の--prefix
引数で指定することができます。Python ライブラリの主要なコレクションはprefix/lib/pythonX.Y
に、プラットフォーム非依存のヘッダファイル (pyconfig.h
を除く全て) はprefix/include/pythonX.Y
にインストールされます。 X.Y は Python のバージョン番号で、例えば2.7
です。
-
sys.
ps1
¶ -
sys.
ps2
¶ インタプリタの一次プロンプト、二次プロンプトを指定する文字列。対話モードで実行中のみ定義され、初期値は
'>>> '
と'... '
です。文字列以外のオブジェクトを指定した場合、インタプリタが対話コマンドを読み込むごとにオブジェクトのstr()
を評価します。この機能は、動的に変化するプロンプトを実装する場合に利用します。
-
sys.
py3kwarning
¶ Python 3 warning flag の状態を格納する Bool 値。 Python が -3 オプションを付けて起動された場合は
True
になります。 (この値は定数として扱ってください。この変数を変更しても、Python 3 warning の動作には影響しません)バージョン 2.6 で追加.
-
sys.
setcheckinterval
(interval)¶ インタプリタの "チェック間隔" を示す整数値を指定します。この値はスレッドスイッチやシグナルハンドラのチェックを行う周期を決定します。デフォルト値は
100
で、この場合 100 の Python 仮想命令を実行するとチェックを行います。この値を大きくすればスレッドを利用するプログラムのパフォーマンスが向上します。この値が 0以下
の場合、各仮想命令を実行するたびにチェックを行い、レスポンス速度が最大になりますがオーバヘッドもまた最大となります。
-
sys.
setdefaultencoding
(name)¶ 現在の Unicode 処理のデフォルトエンコーディング名を設定します。 name に一致するエンコーディングが見つからない場合、
LookupError
が発生します。この関数は、site
モジュールの実装が、sitecustomize
モジュールから使用するためだけに定義されています。site
から呼び出された後、この関数はsys
から削除されます。バージョン 2.0 で追加.
-
sys.
setdlopenflags
(n)¶ インタプリタが拡張モジュールをロードする時、
dlopen()
で使用するフラグを設定します。sys.setdlopenflags(0)
とすれば、モジュールインポート時にシンボルの遅延解決を行う事ができます。シンボルを拡張モジュール間で共有する場合には、sys.setdlopenflags(dl.RTLD_NOW | dl.RTLD_GLOBAL)
と指定します。フラグの定義名はdl
かDLFCN
で定義されています。DLFCN
が存在しない場合、 h2py スクリプトを使って/usr/include/dlfcn.h
から生成することができます。バージョン 2.2 で追加.
-
sys.
setprofile
(profilefunc)¶ Set the system’s profile function, which allows you to implement a Python source code profiler in Python. See chapter Python プロファイラ for more information on the Python profiler. The system’s profile function is called similarly to the system’s trace function (see
settrace()
), but it is called with different events, for example it isn’t called for each executed line of code (only on call and return, but the return event is reported even when an exception has been set). The function is thread-specific, but there is no way for the profiler to know about context switches between threads, so it does not make sense to use this in the presence of multiple threads. Also, its return value is not used, so it can simply returnNone
.Profile functions should have three arguments: frame, event, and arg. frame is the current stack frame. event is a string:
'call'
,'return'
,'c_call'
,'c_return'
, or'c_exception'
. arg depends on the event type.event には以下の意味があります。
'call'
- A function is called (or some other code block entered). The
profile function is called; arg is
None
. 'return'
- A function (or other code block) is about to return. The profile
function is called; arg is the value that will be returned, or
None
if the event is caused by an exception being raised. 'c_call'
- C 関数(拡張関数かビルトイン関数)が呼ばれようとしている。 arg は C 関数オブジェクト。
'c_return'
- C 関数から戻った。 arg は C の関数オブジェクト。
'c_exception'
- C 関数が例外を発生させた。 arg は C の関数オブジェクト。
-
sys.
setrecursionlimit
(limit)¶ Python インタプリタの、スタックの最大の深さを limit に設定します。この制限は Python プログラムが無限に再帰し、 C スタックがオーバーフローしてクラッシュすることを防止するために設けられています。
limit の最大値はプラットフォームによって異なります。深い再帰処理が必要な場合にはプラットフォームがサポートしている範囲内でより大きな値を指定することができますが、この値が大きすぎればクラッシュするので注意が必要です。
-
sys.
settrace
(tracefunc)¶ システムのトレース関数を登録します。トレース関数は Python のソースデバッガを実装するために使用できます。トレース関数はスレッド毎に設定することができるので、デバッグを行うすべてのスレッドで
settrace()
を呼び出し、トレース関数を登録してください。Trace functions should have three arguments: frame, event, and arg. frame is the current stack frame. event is a string:
'call'
,'line'
,'return'
or'exception'
. arg depends on the event type.trace 関数は (event に
'call'
を渡された状態で) 新しいローカルスコープに入るたびに呼ばれます。この場合、そのスコープで利用するローカルの trace 関数への参照か、そのスコープを trace しないのであればNone
を返します。ローカル trace 関数は自身への参照 (もしくはそのスコープの以降の trace を行う別の関数) を返すべきです。もしくは、そのスコープの trace を止めるために
None
を返します。event には以下の意味があります。
'call'
- 関数が呼び出された(もしくは、何かのコードブロックに入った)。グローバルの trace 関数が呼ばれる。 arg は
None
が渡される。戻り値はローカルの trace 関数。 'line'
- インタプリタがコードの新しい行を実行しようとしている、または、ループの条件で再実行しようとしている。ローカルの trace 関数が呼ばれる。arg は
None
。返り値は新しいローカルの trace 関数。これがどのように動作するかの詳細な説明は、Objects/lnotab_notes.txt
を参照のこと。 'return'
- 関数(あるいは別のコードブロック)から戻ろうとしている。ローカルの trace 関数が呼ばれる。 arg は返されようとしている値、または、このイベントが例外が送出されることによって起こったなら
None
。 trace 関数の戻り値は無視される。 'exception'
- 例外が発生した。ローカルの trace 関数が呼ばれる。 arg は
(exception, value, traceback)
のタプル。戻り値は新しいローカルの trace 関数。
例外が呼び出しチェインを辿って伝播していくことに注意してください。
'exception'
イベントは各レベルで発生します。code と frame オブジェクトについては、 標準型の階層 を参照してください。
CPython 実装の詳細:
settrace()
関数は、デバッガ、プロファイラ、カバレッジツール等で使うためだけのものです。この関数の挙動は言語定義よりも実装プラットフォームの分野の問題で、全ての Python 実装で利用できるとは限りません。
-
sys.
settscdump
(on_flag)¶ on_flag が真の場合、Pentium タイムスタンプカウンタを使った VM 計測結果のダンプ出力を有効にします。 on_flag をオフにするとダンプ出力を無効化します。この関数は Python を
--with-tsc
つきでコンパイルしたときにのみ利用できます。ダンプの内容を理解したければ、 Python ソースコード中のPython/ceval.c
を読んでください。バージョン 2.4 で追加.
CPython 実装の詳細: この関数は CPython の実装の詳細に密接に結びついています、そのため他の Python 実装では実装されていないでしょう。
-
sys.
stdin
¶ -
sys.
stdout
¶ -
sys.
stderr
¶ インタプリタの標準入力・標準出力・標準エラー出力に対応するファイルオブジェクト。
stdin
はスクリプトの読み込みを除く全ての入力処理で使用され、input()
やraw_input()
もstdin
から読み込みます。stdout
は、print
や式(expression)の評価結果、input()
,raw_input()
のプロンプトの出力先となります。インタプリタのプロンプトは(ほとんど)stderr
に出力されます。stdout
とstderr
は必ずしも組み込みのファイルオブジェクトである必要はなく、write()
メソッドを持つオブジェクトであれば使用することができます。stdout
とstderr
を別のオブジェクトに置き換えても、os.popen()
,os.system()
,os
のexec*()
などから起動されたプロセスが使用する標準 I/O ストリームは変更されません。
-
sys.
__stdin__
¶ -
sys.
__stdout__
¶ -
sys.
__stderr__
¶ それぞれ起動時の
stdin
,stderr
,stdout
の値を保存しています。終了処理時に利用されます。また、sys.std*
オブジェクトが(訳注:別のファイルライクオブジェクトに)リダイレクトされている場合でも、実際の標準ストリームへの出力に利用できます。また、標準ストリームが壊れたオブジェクトに置き換えられた場合に、動作する実際のファイルを復元するために利用することもできます。しかし、明示的に置き換え前のストリームを保存しておき、そのオブジェクトを復元る事を推奨します。
-
sys.
subversion
¶ 3つ組 (repo, branch, version) で Python インタプリタの Subversion 情報を表します。 repo はリポジトリの名前で、
'CPython'
。 branch は'trunk'
,'branches/name'
または'tags/name'
のいずれかの形式の文字列です。 version はもしインタプリタが Subversion のチェックアウトからビルドされたものならばsvnversion
の出力であり、リビジョン番号 (範囲) とローカルでの変更がある場合には最後に 'M' が付きます。ツリーがエクスポートされたもの (または svnversion が取得できない) で、 branch がタグならばInclude/patchlevel.h
のリビジョンになります。それ以外の場合にはNone
です。バージョン 2.5 で追加.
注釈
現在 Python は Mercurial を使って 開発されています 。現在の Python 2.7 バグフィクスリリースでは、
subversion
はそれゆえプレースホルダです。Python 3.3 では削除されました。
-
sys.
tracebacklimit
¶ 捕捉されない例外が発生した時、出力されるトレースバック情報の最大レベル数を指定する整数値(デフォルト値は
1000
)。0
以下の値が設定された場合、トレースバック情報は出力されず例外型と例外値のみが出力されます。
-
sys.
version
¶ Python インタプリタのバージョン番号の他、ビルド番号や使用コンパイラなどの情報を示す文字列です。この文字列は Python 対話型インタプリタが起動した時に表示されます。バージョン情報はここから抜き出さずに、
version_info
およびplatform
が提供する関数を使って下さい。
-
sys.
api_version
¶ 使用中のインタプリタの C API バージョン。 Python と拡張モジュール間の不整合をデバッグする場合などに利用できます。
バージョン 2.3 で追加.
-
sys.
version_info
¶ バージョン番号を示す 5 要素タプル:major, minor, micro, releaselevel, serial 。 releaselevel 以外は全て整数です。 releaselevel の値は、
'alpha'
,'beta'
,'candidate'
,'final'
の何れかです。 Python 2.0 のversion_info
は、(2, 0, 0, 'final', 0)
となります。構成要素には名前でもアクセスできるので、sys.version_info[0]
はsys.version_info.major
と等価、などになります。バージョン 2.0 で追加.
バージョン 2.7 で変更: 構成する属性に名前をつけました。
-
sys.
winver
¶ Windows プラットフォームで、レジストリのキーとなるバージョン番号。 Python DLL の文字列リソース 1000 に設定されています。通常、この値は
version
の先頭三文字となります。この値は参照専用で、別の値を設定しても Python が使用するレジストリキーを変更することはできません。利用できる環境: Windows。
出典
[C99] | ISO/IEC 9899:1999. "Programming languages – C." この標準のパブリックドラフトが参照できます: http://www.open-std.org/jtc1/sc22/wg14/www/docs/n1256.pdf。 |