code
--- インタープリター基底クラス¶
ソースコード: Lib/code.py
code
モジュールはread-eval-print (読み込み-評価-表示)ループをPythonで実装するための機能を提供します。対話的なインタプリタプロンプトを提供するアプリケーションを作るために使える二つのクラスと便利な関数が含まれています。
- class code.InteractiveInterpreter(locals=None)¶
This class deals with parsing and interpreter state (the user's namespace); it does not deal with input buffering or prompting or input file naming (the filename is always passed in explicitly). The optional locals argument specifies the dictionary in which code will be executed; it defaults to a newly created dictionary with key
'__name__'
set to'__console__'
and key'__doc__'
set toNone
.
- class code.InteractiveConsole(locals=None, filename='<console>')¶
Closely emulate the behavior of the interactive Python interpreter. This class builds on
InteractiveInterpreter
and adds prompting using the familiarsys.ps1
andsys.ps2
, and input buffering.
- code.interact(banner=None, readfunc=None, local=None, exitmsg=None)¶
Convenience function to run a read-eval-print loop. This creates a new instance of
InteractiveConsole
and sets readfunc to be used as theInteractiveConsole.raw_input()
method, if provided. If local is provided, it is passed to theInteractiveConsole
constructor for use as the default namespace for the interpreter loop. Theinteract()
method of the instance is then run with banner and exitmsg passed as the banner and exit message to use, if provided. The console object is discarded after use.バージョン 3.6 で変更: exitmsg 引数が追加されました.
- code.compile_command(source, filename='<input>', symbol='single')¶
この関数はPythonのインタプリタメインループ(別名、read-eval-printループ)をエミュレートしようとするプログラムにとって役に立ちます。扱いにくい部分は、ユーザが(完全なコマンドや構文エラーではなく)さらにテキストを入力すれば完全になりうる不完全なコマンドを入力したときを決定することです。この関数は ほとんど の場合に実際のインタプリタメインループと同じ決定を行います。
source はソース文字列です。filename はオプションのソースが読み出されたファイル名で、デフォルトで
'<input>'
です。symbol はオプションの文法の開始記号で、'single'
(デフォルト)または'eval'
か'exec'
にすべきです。コマンドが完全で有効ならば、コードオブジェクトを返します(
compile(source, filename, symbol)
と同じ)。コマンドが完全でないならば、None
を返します。コマンドが完全で構文エラーを含む場合は、SyntaxError
を発生させます。または、コマンドが無効なリテラルを含む場合は、OverflowError
もしくはValueError
を発生させます。
対話的なインタプリタオブジェクト¶
- InteractiveInterpreter.runsource(source, filename='<input>', symbol='single')¶
インタプリタ内のあるソースをコンパイルし実行します。引数は
compile_command()
のものと同じです。 filename のデフォルトは'<input>'
で、 symbol は'single'
です。あるいくつかのことが起きる可能性があります:入力が不正。
compile_command()
が例外(SyntaxError
かOverflowError
)を起こした場合。showsyntaxerror()
メソッドの呼び出によって、構文トレースバックが表示されるでしょう。runsource()
はFalse
を返します。入力が完全でなく、さらに入力が必要。
compile_command()
がNone
を返した場合。runsource()
はTrue
を返します。入力が完全。
compile_command()
がコードオブジェクトを返した場合。 (SystemExit
を除く実行時例外も処理する)runcode()
を呼び出すことによって、コードは実行されます。runsource()
はFalse
を返します。
戻り値は、次の行のプロンプトに
sys.ps1
かsys.ps2
のどちらを使うのか判断するために使えます。
- InteractiveInterpreter.runcode(code)¶
コードオブジェクトを実行します。例外が生じたときは、トレースバックを表示するために
showtraceback()
が呼び出されます。伝搬することが許されているSystemExit
を除くすべての例外が捉えられます。KeyboardInterrupt
についての注意。このコードの他の場所でこの例外が生じる可能性がありますし、常に捕らえることができるとは限りません。呼び出し側はそれを処理するために準備しておくべきです。
- InteractiveInterpreter.showsyntaxerror(filename=None)¶
起きたばかりの構文エラーを表示します。複数の構文エラーに対して一つあるのではないため、これはスタックトレースを表示しません。 filename が与えられた場合は、Pythonのパーサが与えるデフォルトのファイル名の代わりに例外の中へ入れられます。なぜなら、文字列から読み込んでいるときはパーサは常に
'<string>'
を使うからです。出力はwrite()
メソッドによって書き込まれます。
- InteractiveInterpreter.showtraceback()¶
起きたばかりの例外を表示します。スタックの最初の項目を取り除きます。なぜなら、それはインタプリタオブジェクトの実装の内部にあるからです。出力は
write()
メソッドによって書き込まれます。バージョン 3.5 で変更: 最初のトレースバックではなく、完全なトレースバックの連鎖が表示されます。
- InteractiveInterpreter.write(data)¶
文字列を標準エラーストリーム(
sys.stderr
)へ書き込みます。必要に応じて適切な出力処理を提供するために、派生クラスはこれをオーバーライドすべきです。
対話的なコンソールオブジェクト¶
InteractiveConsole
クラスは InteractiveInterpreter
のサブクラスです。以下の追加メソッドだけでなく、インタプリタオブジェクトのすべてのメソッドも提供します。
- InteractiveConsole.interact(banner=None, exitmsg=None)¶
対話的な Python コンソールをそっくりにエミュレートします。オプションの banner 引数は最初のやりとりの前に表示するバナーを指定します。デフォルトでは、標準 Python インタプリタが表示するものと同じようなバナーを表示します。それに続けて、実際のインタプリタと混乱しないように (とても似ているから!) 括弧の中にコンソールオブジェクトのクラス名を表示します。
オプション引数の exitmsg は、終了時に出力される終了メッセージを指定します。空文字列を渡すと、出力メッセージを抑止します。もし、 exitmsg が与えられないか、
None
の場合は、デフォルトのメッセージが出力されます。バージョン 3.4 で変更: バナーの表示を抑制するには、空の文字列を渡してください。
バージョン 3.6 で変更: 終了時に、終了メッセージを表示します。
- InteractiveConsole.push(line)¶
ソーステキストの一行をインタープリターへ送ります。その行の末尾に改行がついていてはいけません。内部に改行を持っているかもしれません。その行はバッファへ追加され、ソースとして連結されたバッファの内容が渡されインタープリターの
runsource()
メソッドが呼び出されます。コマンドが実行されたか、有効であることをこれが示している場合は、バッファはリセットされます。そうでなければ、コマンドが不完全で、その行が付加された後のままバッファは残されます。さらに入力が必要ならば、戻り値はTrue
です。その行がある方法で処理されたならば、False
です(これはrunsource()
と同じです)。
- InteractiveConsole.resetbuffer()¶
入力バッファから処理されていないソーステキストを取り除きます。