35.6. termios — POSIX スタイルの端末制御¶
This module provides an interface to the POSIX calls for tty I/O control. For a complete description of these calls, see termios(3) Unix manual page. It is only available for those Unix versions that support POSIX termios style tty I/O control configured during installation.
このモジュールの関数は全て、ファイル記述子 fd を最初の引数としてとります。この値は、 sys.stdin.fileno() が返すような整数のファイル記述子でも、 sys.stdin 自体のような file object でもかまいません。
このモジュールではまた、モジュールで提供されている関数を使う上で必要となる全ての定数を定義しています; これらの定数は C の対応する関数と同じ名前を持っています。これらの端末制御インタフェースを利用する上でのさらなる情報については、あなたのシステムのドキュメンテーションを参考にしてください。
このモジュールには、以下の関数が定義されています:
- 
termios.tcgetattr(fd)¶ ファイル記述子 fd の端末属性を含むリストを返します。その形式は:
[iflag, oflag, cflag, lflag, ispeed, ospeed, cc]です。 cc は端末特殊文字のリストです (それぞれ長さ 1 の文字列です。ただしインデクスVMINおよびVTIMEの内容は、それらのフィールドが定義されていた場合整数の値となります)。端末設定フラグおよび端末速度の解釈、および配列 cc のインデクス検索は、termiosで定義されているシンボル定数を使って行わなければなりません。
- 
termios.tcsetattr(fd, when, attributes)¶ ファイル記述子 fd の端末属性を attributes から取り出して設定します。 attributes は
tcgetattr()が返すようなリストです。引数 when は属性がいつ変更されるかを決定します:TCSANOWは即時変更を行い、TCSADRAINは現在キューされている出力を全て転送した後に変更を行い、TCSAFLUSHは現在キューされている出力を全て転送し、全てのキューされている入力を無視した後に変更を行います。
- 
termios.tcsendbreak(fd, duration)¶ ファイル記述子 fd にブレークを送信します。duration をゼロにすると、0.25–0.5 秒間のブレークを送信します; duration の値がゼロでない場合、その意味はシステム依存です。
- 
termios.tcdrain(fd)¶ ファイル記述子 fd に書き込まれた全ての出力が転送されるまで待ちます。
- 
termios.tcflush(fd, queue)¶ ファイル記述子 fd にキューされたデータを無視します。どのキューかは queue セレクタで指定します:
TCIFLUSHは入力キュー、TCOFLUSHは出力キュー、TCIOFLUSHは両方のキューです。
- 
termios.tcflow(fd, action)¶ ファイル記述子 fd の入力または出力をサスペンドしたりレジュームしたりします。引数 action は出力をサスペンドする
TCOOFF、出力をレジュームするTCOON、入力をサスペンドするTCIOFF、入力をレジュームするTCIONをとることができます。
参考
ttyモジュール- 一般的な端末制御操作のための便利な関数。
 
35.6.1. 使用例¶
以下はエコーバックを切った状態でパスワード入力を促す関数です。ユーザの入力に関わらず以前の端末属性を正確に回復するために、二つの tcgetattr() と try … finally 文によるテクニックが使われています:
def getpass(prompt="Password: "):
    import termios, sys
    fd = sys.stdin.fileno()
    old = termios.tcgetattr(fd)
    new = termios.tcgetattr(fd)
    new[3] = new[3] & ~termios.ECHO          # lflags
    try:
        termios.tcsetattr(fd, termios.TCSADRAIN, new)
        passwd = input(prompt)
    finally:
        termios.tcsetattr(fd, termios.TCSADRAIN, old)
    return passwd
