1. コマンドラインと環境¶
CPython インタプリタはコマンドラインと環境を読み取って様々な設定を行ないます。
CPython implementation detail: 他の実装のコマンドラインスキームは CPython とは異なります。さらなる情報は 別のPythonの実装 を参照してください。
1.1. コマンドライン¶
Python を起動するとき、以下のうち任意のオプションを指定できます:
python [-bBdEhiIOqsSuvVWx?] [-c command | -m module-name | script | - ] [args]
もちろん、もっとも一般的な利用方法は、単純にスクリプトを起動することです:
python myscript.py
1.1.1. インターフェイスオプション¶
インタプリタのインターフェイスは UNIX シェルのものに似ていますが、より多くの起動方法を提供しています:
tty デバイスに接続された標準入力とともに起動された場合、 EOF (end-of-file 文字。 UNIX では Ctrl-D で、Windows では Ctrl-Z, Enter で入力可能) を受け取るまで、コマンドを受け取り、それを実行します。
ファイル名引数か、標準入力としてファイルを渡された場合、そのファイルからスクリプトを読み込んで実行します。
ディレクトリ名を引数に受け取った場合、そのディレクトリから適切な名前のスクリプトファイルを読み込んで実行します。
-c コマンドオプションを利用して起動された場合、 コマンド として渡された Python の文を実行します。 コマンド の部分には改行で区切られた複数行を指定することもできます。行の先頭の空白文字は Python 文の重要要素です!-m モジュール名として Python モジュールパスにあるモジュールを指定された場合、そのモジュールをスクリプトとして実行します。
非インタラクティブモードでは、入力の全体が実行前にパースされます。
インタプリタによって消費されるオプションリストが終了したあと、継続する全ての引数は sys.argv に渡ります。 -- ただし、添字 0 の先頭要素(sys.argv[0]) はプログラムのソース自体を示す文字列です。
-
-c<command>¶ command 内の Python コードを実行します。 command は改行によって区切られた1行以上の文です。通常のモジュールのコードと同じく、行頭の空白文字は意味を持ちます。
このオプションが指定された場合、
sys.argvの最初の要素は"-c"になり、カレントディレクトリがsys.pathの先頭に追加されます (そのディレクトリにあるモジュールをトップレベルモジュールとして import 出来るようになります)。
-
-m<module-name>¶ sys.pathから指定されたモジュール名のモジュールを探し、その内容を__main__モジュールとして実行します。引数は module 名なので、拡張子 (
.py) を含めてはいけません。モジュール名は有効な Python の絶対モジュール名 (absolute module name) であるべきですが、実装がそれを強制しているとは限りません (例えば、ハイフンを名前に含める事を許可するかもしれません)。パッケージ名 (名前空間パッケージも含む) でも構いません。通常のモジュールの代わりにパッケージ名が与えられた場合、インタプリタは
<pkg>.__main__を main モジュールとして実行します。この挙動はスクリプト引数として渡されたディレクトリや zip ファイルをインタプリタが処理するのと意図的に同じにしています。注釈
このオプションは組み込みモジュールや C で書かれた拡張モジュールには利用できません。 Python モジュールファイルを持っていないからです。しかし、コンパイル済みのモジュールは、たとえ元のソースファイルがなくても利用可能です。
このオプションが指定された場合、
sys.argvの最初の要素はモジュールファイルのフルパスになります (モジュールファイルを検索している間、最初の要素は"-m"に設定されます)。-cオプションと同様に、カレントディレクトリがsys.pathの先頭に追加されます。-Ioption can be used to run the script in isolated mode wheresys.pathcontains neither the current directory nor the user's site-packages directory. AllPYTHON*environment variables are ignored, too.多くの標準ライブラリモジュールにはスクリプトとして実行された時のためのコードがあります。例えば、
timeitモジュールは次のように実行可能です:python -m timeit -s 'setup here' 'benchmarked code here' python -m timeit -h # for details
バージョン 3.1 で変更:
__main__サブモジュールを実行するパッケージ名が提供されました。バージョン 3.4 で変更: 名前空間パッケージもサポートされました
-
- 標準入力 (
sys.stdin) からコマンドを読み込みます。標準入力がターミナルだった場合、暗黙的に-iオプションが指定されます。このオプションが指定された場合、
sys.argvの最初の要素は"-"で、カレントディレクトリがsys.pathの先頭に追加されます。
-
<script> script 内の Python コードを実行します。 script は、Python ファイル、
__main__.pyファイルがあるディレクトリ、__main__.pyファイルがある zip ファイルのいずれかの、ファイルシステム上の (絶対または相対) パスでなければなりません。このオプションが指定された場合、
sys.argvの最初の要素はコマンドラインで指定されたスクリプト名になります。スクリプト名が Python ファイルを直接指定していた場合、そのファイルを含むディレクトリが
sys.pathの先頭に追加され、そのファイルは__main__モジュールとして実行されます。スクリプト名がディレクトリか zip ファイルを指定していた場合、スクリプト名が
sys.pathに追加され、その中の__main__.pyファイルが__main__モジュールとして実行されます。-Ioption can be used to run the script in isolated mode wheresys.pathcontains neither the script's directory nor the user's site-packages directory. AllPYTHON*environment variables are ignored, too.参考
runpy.run_path()Python コードで直接使える等価な機能
インターフェイスオプションが与えられなかった場合、-i が暗黙的に指定され、sys.argv[0] が空の文字列 ("") になり、 現在のディレクトリが sys.path の先頭に追加されます。また、利用可能であればタブ補完と履歴編集が自動的に有効かされます (readline の設定 を参照してください)。
参考
バージョン 3.4 で変更: タブ補完と履歴の編集が自動的に有効化されます。
1.1.2. 一般オプション¶
1.1.3. その他のオプション¶
-
-b¶ bytesまたはbytearrayをstrと比較した場合、または、bytesをintと比較した場合に警告を発生させます。このオプションを2度指定した場合 (-bb) は、エラーを発生させます。
-
-B¶ 与えられた場合、Python はソースモジュールのインポート時に
.pycファイルの作成を試みません。PYTHONDONTWRITEBYTECODE環境変数も参照してください。
-
--check-hash-based-pycsdefault|always|never¶ Control the validation behavior of hash-based
.pycfiles. See キャッシュされたバイトコードの無効化. When set todefault, checked and unchecked hash-based bytecode cache files are validated according to their default semantics. When set toalways, all hash-based.pycfiles, whether checked or unchecked, are validated against their corresponding source file. When set tonever, hash-based.pycfiles are not validated against their corresponding source files.The semantics of timestamp-based
.pycfiles are unaffected by this option.
-
-d¶ パーサーのデバッグ出力を有効にします。(専門家専用です。コンパイルオプションに依存します)。
PYTHONDEBUGも参照してください。
-
-E¶ 全ての
PYTHON*環境変数を無視します。例えば、PYTHONPATHやPYTHONHOMEなどです。
-
-i¶ 最初の引数にスクリプトが指定された場合や
-cオプションが利用された場合、sys.stdinがターミナルに出力されない場合も含めて、スクリプトかコマンドを実行した後にインタラクティブモードに入ります。PYTHONSTARTUPファイルは読み込みません。このオプションはグローバル変数や、スクリプトが例外を発生させるときにそのスタックトレースを調べるのに便利です。
PYTHONINSPECTも参照してください。
-
-I¶ Python を隔離モードで実行します。-E と -s も暗黙的に指定されます。隔離モードでは
sys.pathはスクリプトのディレクトリやユーザのサイトパッケージのディレクトリを含みません。全PYTHON*環境変数も無視されます。ユーザが悪意のあるコードを注入するのを防ぐために更なる制限が課されるかもしれません。バージョン 3.4 で追加.
-
-O¶ Remove assert statements and any code conditional on the value of
__debug__. Augment the filename for compiled (bytecode) files by adding.opt-1before the.pycextension (see PEP 488). See alsoPYTHONOPTIMIZE.バージョン 3.5 で変更: PEP 488 に従って
.pycファイル名を変更します。
-
-OO¶ Do
-Oand also discard docstrings. Augment the filename for compiled (bytecode) files by adding.opt-2before the.pycextension (see PEP 488).バージョン 3.5 で変更: PEP 488 に従って
.pycファイル名を変更します。
-
-q¶ インタラクティブモードでも copyright とバージョンのメッセージを表示しません。
バージョン 3.2 で追加.
-
-R¶ Turn on hash randomization. This option only has an effect if the
PYTHONHASHSEEDenvironment variable is set to0, since hash randomization is enabled by default.以前のバージョンの Python では、このオプションはハッシュのランダム化を有効にします。これにより、 str, bytes, datetime 型の
__hash__()値が予測不可能な乱数で "ソルト" されます。ハッシュ値は各 Python プロセスでは固定ですが、 Python を繰り返し再実行した場合は別の予測不能な値になります。ハッシュのランダム化は、dict の生成コストが最悪の O(n^2) になるように注意深く選ばれた入力値を与えることによる DoS 攻撃への防御策として提供されています。詳細は http://www.ocert.org/advisories/ocert-2011-003.html を参照してください。
PYTHONHASHSEEDによってハッシュシードの固定値を秘密にすることが出来ます。バージョン 3.7 で変更: このオプションが無視されなくなりました.
バージョン 3.2.3 で追加.
-
-s¶ user site-packages directoryをsys.pathに追加しません。参考
PEP 370 -- ユーザごとの
site-packagesディレクトリ
-
-S¶ siteモジュールの import と、そのモジュールが行なっていた site ごとのsys.pathへの操作を無効にします。後にsiteを明示的に import しても、これらの操作は実行されません (実行したい場合は、site.main()を呼び出してください)。
-
-u¶ Force the stdout and stderr streams to be unbuffered. This option has no effect on the stdin stream.
PYTHONUNBUFFEREDも参照してください。バージョン 3.7 で変更: The text layer of the stdout and stderr streams now is unbuffered.
-
-v¶ モジュールが初期化されるたびに、それがどこ(ファイル名やビルトインモジュール) からロードされたのかを示すメッセージを出力します。 二重に指定された場合(
-vv)は、モジュールを検索するときにチェックされた各ファイルに対してメッセージを出力します。また、終了時のモジュールクリーンアップに関する情報も提供します。PYTHONVERBOSEも参照してください。
-
-Warg¶ 警告制御。 Python の警告機構はデフォルトでは警告メッセージを
sys.stderrに表示します。典型的な警告メッセージは次の書式で表示されます。file:line: category: message
デフォルトでは、各警告は発生したソース行ごとに一度だけ表示されます。このオプションは、警告をどれくらいの頻度で表示するかを制御します。
複数の
-Wオプションを指定することができます。警告が1つ以上のオプションとマッチしたときは、最後にマッチしたオプションのアクションが有効になります。不正な-Wオプションは無視されます (最初の警告が発生したときに、不正なオプションに対する警告メッセージが表示されます)。警告は、
PYTHONWARNINGS環境変数を使い、そして Python プログラムの中からwarningsモジュールを利用して制御できます。The simplest settings apply a particular action unconditionally to all warnings emitted by a process (even those that are otherwise ignored by default):
-Wdefault # Warn once per call location -Werror # Convert to exceptions -Walways # Warn every time -Wmodule # Warn once per calling module -Wonce # Warn once per Python process -Wignore # Never warn
The action names can be abbreviated as desired (e.g.
-Wi,-Wd,-Wa,-We) and the interpreter will resolve them to the appropriate action name.See 警告フィルタ and Describing Warning Filters for more details.
-
-x¶ Unix 以外の形式の
#!cmdを使うために、ソースの最初の行をスキップします。これは、DOS専用のハックのみを目的としています。
-
-X¶ 様々な実装固有のオプションのために予約されています。現在のところ CPython は以下の値を定義しています:
-X faulthandlerはfaulthandlerを有効化します;-X showrefcountto output the total reference count and number of used memory blocks when the program finishes or after each statement in the interactive interpreter. This only works on debug builds.-X tracemallocはtracemallocモジュールを用いて Python のメモリ割り当てのトレースを開始します。デフォルトでは最新のフレームのみがトレースのトレースバックに格納されます。最大 NFRAME フレームのトレースバックで トレースを開始するには-X tracemalloc=NFRAMEを使用してください。詳細はtracemalloc.start()を参照してください。-X showalloccountto output the total count of allocated objects for each type when the program finishes. This only works when Python was built withCOUNT_ALLOCSdefined.-X int_max_str_digitsconfigures the integer string conversion length limitation. See alsoPYTHONINTMAXSTRDIGITS.-X importtimeto show how long each import takes. It shows module name, cumulative time (including nested imports) and self time (excluding nested imports). Note that its output may be broken in multi-threaded application. Typical usage ispython3 -X importtime -c 'import asyncio'. See alsoPYTHONPROFILEIMPORTTIME.-X dev: enable CPython's "development mode", introducing additional runtime checks which are too expensive to be enabled by default. It should not be more verbose than the default if the code is correct: new warnings are only emitted when an issue is detected. Effect of the developer mode:Add
defaultwarning filter, as-Wdefault.Install debug hooks on memory allocators: see the
PyMem_SetupDebugHooks()C function.Enable the
faulthandlermodule to dump the Python traceback on a crash.Enable asyncio debug mode.
Set the
dev_modeattribute ofsys.flagstoTrue.
-X utf8enables UTF-8 mode for operating system interfaces, overriding the default locale-aware mode.-X utf8=0explicitly disables UTF-8 mode (even when it would otherwise activate automatically). SeePYTHONUTF8for more details.
任意の値を渡し、
sys._xoptions辞書から取り出すことも出来ます。バージョン 3.2 で変更:
-Xオプションが追加されました。バージョン 3.3 で追加:
-X faulthandlerオプション。バージョン 3.4 で追加:
-X showrefcountおよび-X tracemallocオプション。バージョン 3.6 で追加:
-X showalloccountオプション。バージョン 3.7 で追加:
-X importtime,-X dev,-X utf8オプション。バージョン 3.7.14 で追加: The
-X int_max_str_digitsoption.
1.1.4. 使うべきでないオプション¶
1.2. 環境変数¶
以下の環境変数は Python の挙動に影響します。環境変数は -E や -I 以外のコマンドラインスイッチの前に処理されます。衝突したときにコマンドラインスイッチが環境変数をオーバーライドするのは慣例です。
-
PYTHONHOME¶ 標準 Python ライブラリの場所を変更します。デフォルトでは、ライブラリは
prefix/lib/pythonversionとexec_prefix/lib/pythonversionから検索されます。ここで、prefixとexec_prefixはインストール依存のディレクトリで、両方共デフォルトでは/usr/localです。PYTHONHOMEが1つのディレクトリに設定されている場合、その値はprefixとexec_prefixの両方を置き換えます。それらに別々の値を指定したい場合は、PYTHONHOMEをprefix:exec_prefixのように指定します。
-
PYTHONPATH¶ モジュールファイルのデフォルトの検索パスを追加します。この環境変数のフォーマットはシェルの
PATHと同じで、os.pathsep(Unix ならコロン、 Windows ならセミコロン) で区切られた1つ以上のディレクトリパスです。存在しないディレクトリは警告なしに無視されます。通常のディレクトリに加えて、
PYTHONPATHのエントリはピュアPython モジュール(ソース形式でもコンパイルされた形式でも) を含む zip ファイルを参照することもできます。拡張モジュールは zip ファイルの中から import することはできません。デフォルトの検索パスはインストール依存ですが、通常は
prefix/lib/pythonversionで始まります。 (上のPYTHONHOMEを参照してください。) これは 常にPYTHONPATHに追加されます。上の インターフェイスオプション で説明されているように、追加の検索パスディレクトリが
PYTHONPATHの手前に追加されます。検索パスは Python プログラムからsys.path変数として操作することができます。
-
PYTHONSTARTUP¶ この変数が読み込み可能なファイル名の場合、対話モードで最初のプロンプトが表示される前にそのファイルの Python コマンドが実行されます。 ファイル内で定義されているオブジェクトやインポートされたオブジェクトを対話セッションで修飾せずに使用するために、ファイルは対話的なコマンドと同じ名前空間で実行されます。 このファイル内のプロンプト
sys.ps1やsys.ps2、ならびにフックsys.__interactivehook__を変更することも出来ます。
-
PYTHONBREAKPOINT¶ If this is set, it names a callable using dotted-path notation. The module containing the callable will be imported and then the callable will be run by the default implementation of
sys.breakpointhook()which itself is called by built-inbreakpoint(). If not set, or set to the empty string, it is equivalent to the value "pdb.set_trace". Setting this to the string "0" causes the default implementation ofsys.breakpointhook()to do nothing but return immediately.バージョン 3.7 で追加.
-
PYTHONINSPECT¶ この変数に空でない文字列を設定するのは
-iオプションを指定するのと等価です。この変数は Python コードから
os.environを使って変更して、プログラム終了時のインスペクトモードを強制することができます。
-
PYTHONDONTWRITEBYTECODE¶ この変数に空でない文字列を設定した場合、 Python はソースモジュールのインポート時に
.pycファイルを作成しようとはしなくなります。-Bオプションを指定するのと等価です。
-
PYTHONHASHSEED¶ この変数が設定されていない場合や
randomに設定された場合、乱数値が str、bytes ならびに datetime オブジェクトのハッシュのシードに使われます。PYTHONHASHSEEDが整数値に設定された場合、その値はハッシュランダム化が扱う型の hash() 生成の固定シードに使われます。その目的は再現性のあるハッシュを可能にすることです。例えばインタープリタ自身の自己テストや Python プロセスのクラスタでハッシュ値を共有するのに用います。
整数は [0,4294967295] の十進数でなければなりません。0 を指定するとハッシュランダム化は無効化されます。
バージョン 3.2.3 で追加.
-
PYTHONINTMAXSTRDIGITS¶ If this variable is set to an integer, it is used to configure the interpreter's global integer string conversion length limitation.
バージョン 3.7.14 で追加.
-
PYTHONIOENCODING¶ この変数がインタープリタ実行前に設定されていた場合、
encodingname:errorhandlerという文法で標準入力/標準出力/標準エラー出力のエンコードを上書きします。encodingnameと:errorhandlerの部分はどちらも任意で、str.encode()と同じ意味を持ちます。標準エラー出力の場合、
:errorhandlerの部分は無視されます; ハンドラは常に'backslashreplace'です。バージョン 3.4 で変更:
encodingnameの部分が任意になりました。バージョン 3.6 で変更: On Windows, the encoding specified by this variable is ignored for interactive console buffers unless
PYTHONLEGACYWINDOWSSTDIOis also specified. Files and pipes redirected through the standard streams are not affected.
-
PYTHONNOUSERSITE¶ この環境変数が設定されている場合、 Python は
ユーザ site-packages ディレクトリをsys.pathに追加しません。参考
PEP 370 -- ユーザごとの
site-packagesディレクトリ
-
PYTHONUSERBASE¶ user base directoryを設定します。これはpython setup.py install --user時にuser site-packages directoryと Distutils installation paths のパスを計算するのに使われます。参考
PEP 370 -- ユーザごとの
site-packagesディレクトリ
-
PYTHONEXECUTABLE¶ この環境変数が設定された場合、
sys.argv[0]に、C ランタイムから取得した値の代わりにこの環境変数の値が設定されます。Mac OS X でのみ動作します。
-
PYTHONWARNINGS¶ This is equivalent to the
-Woption. If set to a comma separated string, it is equivalent to specifying-Wmultiple times, with filters later in the list taking precedence over those earlier in the list.The simplest settings apply a particular action unconditionally to all warnings emitted by a process (even those that are otherwise ignored by default):
PYTHONWARNINGS=default # Warn once per call location PYTHONWARNINGS=error # Convert to exceptions PYTHONWARNINGS=always # Warn every time PYTHONWARNINGS=module # Warn once per calling module PYTHONWARNINGS=once # Warn once per Python process PYTHONWARNINGS=ignore # Never warn
See 警告フィルタ and Describing Warning Filters for more details.
-
PYTHONFAULTHANDLER¶ この環境変数が空でない文字列に設定された場合、起動時に
faulthandler.enable()が呼び出されます。Python のトレースバックをダンプするためにSIGSEGV、SIGFPE、SIGABRT、SIGBUSおよびSIGILLシグナルのハンドラを導入します。-Xfaulthandlerオプションと等価です。バージョン 3.3 で追加.
-
PYTHONTRACEMALLOC¶ この環境変数が空でない文字列に設定された場合、
tracemallocモジュールを利用して Python のメモリ割り当てのトレースを開始します。変数の値はトレース時のトレースバックで保持されるフレームの最大数です。例えばPYTHONTRACEMALLOC=1の場合、最新のフレームのみを保持します。詳細はtracemalloc.start()を参照してください、バージョン 3.4 で追加.
-
PYTHONPROFILEIMPORTTIME¶ If this environment variable is set to a non-empty string, Python will show how long each import takes. This is exactly equivalent to setting
-X importtimeon the command line.バージョン 3.7 で追加.
-
PYTHONMALLOC¶ Set the Python memory allocators and/or install debug hooks.
Set the family of memory allocators used by Python:
default: use the default memory allocators.malloc: use themalloc()function of the C library for all domains (PYMEM_DOMAIN_RAW,PYMEM_DOMAIN_MEM,PYMEM_DOMAIN_OBJ).pymalloc: use the pymalloc allocator forPYMEM_DOMAIN_MEMandPYMEM_DOMAIN_OBJdomains and use themalloc()function for thePYMEM_DOMAIN_RAWdomain.
Install debug hooks:
debug: install debug hooks on top of the default memory allocators.malloc_debug: same asmallocbut also install debug hooks.pymalloc_debug: same aspymallocbut also install debug hooks.
See the default memory allocators and the
PyMem_SetupDebugHooks()function (install debug hooks on Python memory allocators).バージョン 3.7 で変更: Added the
"default"allocator.バージョン 3.6 で追加.
-
PYTHONMALLOCSTATS¶ If set to a non-empty string, Python will print statistics of the pymalloc memory allocator every time a new pymalloc object arena is created, and on shutdown.
This variable is ignored if the
PYTHONMALLOCenvironment variable is used to force themalloc()allocator of the C library, or if Python is configured withoutpymallocsupport.バージョン 3.6 で変更: This variable can now also be used on Python compiled in release mode. It now has no effect if set to an empty string.
-
PYTHONLEGACYWINDOWSFSENCODING¶ If set to a non-empty string, the default filesystem encoding and errors mode will revert to their pre-3.6 values of 'mbcs' and 'replace', respectively. Otherwise, the new defaults 'utf-8' and 'surrogatepass' are used.
This may also be enabled at runtime with
sys._enablelegacywindowsfsencoding().利用可能な環境: Windows 。
バージョン 3.6 で追加: より詳しくは PEP 529 を参照をしてください。
-
PYTHONLEGACYWINDOWSSTDIO¶ If set to a non-empty string, does not use the new console reader and writer. This means that Unicode characters will be encoded according to the active console code page, rather than using utf-8.
This variable is ignored if the standard streams are redirected (to files or pipes) rather than referring to console buffers.
利用可能な環境: Windows 。
バージョン 3.6 で追加.
-
PYTHONCOERCECLOCALE¶ If set to the value
0, causes the main Python command line application to skip coercing the legacy ASCII-based C and POSIX locales to a more capable UTF-8 based alternative.If this variable is not set (or is set to a value other than
0), theLC_ALLlocale override environment variable is also not set, and the current locale reported for theLC_CTYPEcategory is either the defaultClocale, or else the explicitly ASCII-basedPOSIXlocale, then the Python CLI will attempt to configure the following locales for theLC_CTYPEcategory in the order listed before loading the interpreter runtime:C.UTF-8C.utf8UTF-8
If setting one of these locale categories succeeds, then the
LC_CTYPEenvironment variable will also be set accordingly in the current process environment before the Python runtime is initialized. This ensures that in addition to being seen by both the interpreter itself and other locale-aware components running in the same process (such as the GNUreadlinelibrary), the updated setting is also seen in subprocesses (regardless of whether or not those processes are running a Python interpreter), as well as in operations that query the environment rather than the current C locale (such as Python's ownlocale.getdefaultlocale()).Configuring one of these locales (either explicitly or via the above implicit locale coercion) automatically enables the
surrogateescapeerror handler forsys.stdinandsys.stdout(sys.stderrcontinues to usebackslashreplaceas it does in any other locale). This stream handling behavior can be overridden usingPYTHONIOENCODINGas usual.For debugging purposes, setting
PYTHONCOERCECLOCALE=warnwill cause Python to emit warning messages onstderrif either the locale coercion activates, or else if a locale that would have triggered coercion is still active when the Python runtime is initialized.Also note that even when locale coercion is disabled, or when it fails to find a suitable target locale,
PYTHONUTF8will still activate by default in legacy ASCII-based locales. Both features must be disabled in order to force the interpreter to useASCIIinstead ofUTF-8for system interfaces.Availability: *nix.
バージョン 3.7 で追加: より詳しくは PEP 538 を参照をしてください。
-
PYTHONDEVMODE¶ If this environment variable is set to a non-empty string, enable the CPython "development mode". See the
-Xdevoption.バージョン 3.7 で追加.
-
PYTHONUTF8¶ If set to
1, enables the interpreter's UTF-8 mode, whereUTF-8is used as the text encoding for system interfaces, regardless of the current locale setting.This means that:
sys.getfilesystemencoding()returns'UTF-8'(the locale encoding is ignored).locale.getpreferredencoding()returns'UTF-8'(the locale encoding is ignored, and the function'sdo_setlocaleparameter has no effect).sys.stdin,sys.stdout, andsys.stderrall use UTF-8 as their text encoding, with thesurrogateescapeerror handler being enabled forsys.stdinandsys.stdout(sys.stderrcontinues to usebackslashreplaceas it does in the default locale-aware mode)
As a consequence of the changes in those lower level APIs, other higher level APIs also exhibit different default behaviours:
Command line arguments, environment variables and filenames are decoded to text using the UTF-8 encoding.
os.fsdecode()andos.fsencode()use the UTF-8 encoding.open(),io.open(), andcodecs.open()use the UTF-8 encoding by default. However, they still use the strict error handler by default so that attempting to open a binary file in text mode is likely to raise an exception rather than producing nonsense data.
Note that the standard stream settings in UTF-8 mode can be overridden by
PYTHONIOENCODING(just as they can be in the default locale-aware mode).If set to
0, the interpreter runs in its default locale-aware mode.Setting any other non-empty string causes an error during interpreter initialisation.
If this environment variable is not set at all, then the interpreter defaults to using the current locale settings, unless the current locale is identified as a legacy ASCII-based locale (as described for
PYTHONCOERCECLOCALE), and locale coercion is either disabled or fails. In such legacy locales, the interpreter will default to enabling UTF-8 mode unless explicitly instructed not to do so.Also available as the
-Xutf8option.バージョン 3.7 で追加: より詳しくは PEP 540 を参照してください。
1.2.1. デバッグモード変数¶
以下の環境変数は、--with-pydebug ビルドオプションを指定して構成されたデバッグビルド版の Python でのみ効果があります。
-
PYTHONTHREADDEBUG¶ 設定された場合、 Python はスレッドデバッグ情報を表示します。
-
PYTHONDUMPREFS¶ 設定された場合、 Python はインタプリタのシャットダウン後に残っているオブジェクトと参照カウントをダンプします。
