tempfile
--- Generate temporary files and directories¶
ソースコード: Lib/tempfile.py
This module creates temporary files and directories. It works on all
supported platforms. TemporaryFile
, NamedTemporaryFile
,
TemporaryDirectory
, and SpooledTemporaryFile
are high-level
interfaces which provide automatic cleanup and can be used as
context managers. mkstemp()
and
mkdtemp()
are lower-level functions which require manual cleanup.
ユーザが呼び出し可能な全ての関数とコンストラクタは追加の引数を受け取ります。 その引数によって一時ファイルやディレクトリの場所と名前を直接操作することが出来ます。 このモジュールに使用されるファイル名はランダムな文字を含みます。そのためファイルは共有された一時ディレクトリに安全に作成されます。 後方互換性を保つために引数の順序は若干奇妙です。 分かりやすさのためにキーワード引数を使用してください。
このモジュールではユーザが呼び出し可能な以下の項目を定義しています:
- tempfile.TemporaryFile(mode='w+b', buffering=-1, encoding=None, newline=None, suffix=None, prefix=None, dir=None, *, errors=None)¶
一時的な記憶領域として使うことの出来る file-like object を返します。 ファイルは
mkstemp()
と同じルールにより安全に作成されます。 オブジェクトは閉じられる (オブジェクトのガベージコレクションによる暗黙的なものも含みます) とすぐに破壊されます。 Unix では、そのファイルのディレクトリエントリは全く作成されないか、ファイル作成後すぐに削除されます。 これは他のプラットフォームではサポートされません。 よって、この関数で作成された一時ファイルがファイルシステムで可視な名前を持つかどうかをコードで当てにすべきではありません。The resulting object can be used as a context manager (see 使用例). On completion of the context or destruction of the file object the temporary file will be removed from the filesystem.
作成されたファイルを閉じることなく読み書きできるように、 mode 引数のデフォルトは
'w+b'
です。 保存されるデータに関わらず全てのプラットフォーム上で一貫して動作するようにバイナリモードが使用されます。 buffering、encoding、errors、newline は、open()
に対する引数として解釈されます。dir、prefix、suffix 引数の意味とデフォルトは
mkstemp()
のものと同じです。返されたオブジェクトは、POSIXプラットフォームでは本物のファイルオブジェクトです。 それ以外のプラットフォームでは、
file
属性が下層の本物のファイルであるファイル様オブジェクトです。The
os.O_TMPFILE
flag is used if it is available and works (Linux-specific, requires Linux kernel 3.11 or later).On platforms that are neither Posix nor Cygwin, TemporaryFile is an alias for NamedTemporaryFile.
引数
fullpath
を指定して 監査イベントtempfile.mkstemp
を送出します。バージョン 3.5 で変更: The
os.O_TMPFILE
flag is now used if available.バージョン 3.8 で変更: errors 引数が追加されました。
- tempfile.NamedTemporaryFile(mode='w+b', buffering=-1, encoding=None, newline=None, suffix=None, prefix=None, dir=None, delete=True, *, errors=None)¶
This function operates exactly as
TemporaryFile()
does, except that the file is guaranteed to have a visible name in the file system (on Unix, the directory entry is not unlinked). That name can be retrieved from thename
attribute of the returned file-like object. Whether the name can be used to open the file a second time, while the named temporary file is still open, varies across platforms (it can be so used on Unix; it cannot on Windows). If delete is true (the default), the file is deleted as soon as it is closed. The returned object is always a file-like object whosefile
attribute is the underlying true file object. This file-like object can be used in awith
statement, just like a normal file.On POSIX (only), a process that is terminated abruptly with SIGKILL cannot automatically delete any NamedTemporaryFiles it created.
引数
fullpath
を指定して 監査イベントtempfile.mkstemp
を送出します。バージョン 3.8 で変更: errors 引数が追加されました。
- class tempfile.SpooledTemporaryFile(max_size=0, mode='w+b', buffering=-1, encoding=None, newline=None, suffix=None, prefix=None, dir=None, *, errors=None)¶
This class operates exactly as
TemporaryFile()
does, except that data is spooled in memory until the file size exceeds max_size, or until the file'sfileno()
method is called, at which point the contents are written to disk and operation proceeds as withTemporaryFile()
.- rollover()¶
The resulting file has one additional method,
rollover()
, which causes the file to roll over to an on-disk file regardless of its size.
The returned object is a file-like object whose
_file
attribute is either anio.BytesIO
orio.TextIOWrapper
object (depending on whether binary or text mode was specified) or a true file object, depending on whetherrollover()
has been called. This file-like object can be used in awith
statement, just like a normal file.バージョン 3.3 で変更: the truncate method now accepts a size argument.
バージョン 3.8 で変更: errors 引数が追加されました。
バージョン 3.11 で変更: Fully implements the
io.BufferedIOBase
andio.TextIOBase
abstract base classes (depending on whether binary or text mode was specified).
- class tempfile.TemporaryDirectory(suffix=None, prefix=None, dir=None, ignore_cleanup_errors=False)¶
This class securely creates a temporary directory using the same rules as
mkdtemp()
. The resulting object can be used as a context manager (see 使用例). On completion of the context or destruction of the temporary directory object, the newly created temporary directory and all its contents are removed from the filesystem.- name¶
The directory name can be retrieved from the
name
attribute of the returned object. When the returned object is used as a context manager, thename
will be assigned to the target of theas
clause in thewith
statement, if there is one.
- cleanup()¶
The directory can be explicitly cleaned up by calling the
cleanup()
method. If ignore_cleanup_errors is true, any unhandled exceptions during explicit or implicit cleanup (such as aPermissionError
removing open files on Windows) will be ignored, and the remaining removable items deleted on a "best-effort" basis. Otherwise, errors will be raised in whatever context cleanup occurs (thecleanup()
call, exiting the context manager, when the object is garbage-collected or during interpreter shutdown).
引数
fullpath
を指定して 監査イベントtempfile.mkdtemp
を送出します。バージョン 3.2 で追加.
バージョン 3.10 で変更: ignore_cleanup_errors 引数が追加されました。
- tempfile.mkstemp(suffix=None, prefix=None, dir=None, text=False)¶
可能な限り最も安全な手段で一時ファイルを生成します。 プラットフォームが
os.open()
のos.O_EXCL
フラグを正しく実装している限り、ファイルの作成で競合が起こることはありません。 作成したユーザのユーザ ID からのみファイルを読み書き出来ます。 プラットフォームがファイルが実行可能かどうかを示す許可ビットを使用している場合、ファイルは誰からも実行不可です。 このファイルのファイル記述子は子プロセスに継承されません。TemporaryFile()
と違って、mkstemp()
のユーザは用済みになった時に一時ファイルを削除しなければなりません。suffix が
None
でない場合、ファイル名はその接尾辞で終わります。 そうでない場合、接尾辞はありません。mkstemp()
はファイル名と接尾辞の間にドットを追加しません。 必要であれば suffix の先頭につけてください。prefix が
None
でない場合、ファイル名はその接頭辞で始まります。 そうでない場合、デフォルトの接頭辞が使われます。 必要に応じ、デフォルトはgettempprefix()
またはgettempprefixb()
の返り値です。dir が
None
でない場合、ファイルはそのディレクトリ下に作成されます。None
の場合、デフォルトのディレクトリが使われます。デフォルトのディレクトリはプラットフォームに依存するリストから選ばれますが、アプリケーションのユーザは TMPDIR、TEMP、または TMP 環境変数を設定することでディレクトリの場所を管理することができます。そのため、生成されるファイル名が、os.popen()
で外部コマンドにクォーティング無しで渡すことができるなどといった、扱いやすい性質を持つ保証はありません。suffix、prefix、dir のいずれかが
None
でない場合、それらは同じ型でなければなりません。 bytes の場合、返された名前は str でなはく bytes です。 他の挙動はデフォルトで返り値を bytes に強制的にしたい場合はsuffix=b''
を渡してください。text に真を指定した場合は、ファイルはテキストモードで開かれます。そうでない場合(デフォルト)は、ファイルはバイナリモードで開かれます。
mkstemp()
は開かれたファイルを扱うための OS レベルのハンドル (os.open()
が返すものと同じ) とファイルの絶対パス名が順番に並んだタプルを返します。引数
fullpath
を指定して 監査イベントtempfile.mkstemp
を送出します。バージョン 3.5 で変更: suffix、prefix、dir は bytes の返り値を得るために bytes で渡すことが出来ます。 それ以前は str のみ許されていました。 適切なデフォルト値を使用するよう、suffix と prefix は
None
を受け入れ、デフォルトにするようになりました。バージョン 3.6 で変更: dir パラメタが path-like object を受け付けるようになりました。
- tempfile.mkdtemp(suffix=None, prefix=None, dir=None)¶
可能な限り安全な方法で一時ディレクトリを作成します。 ディレクトリの生成で競合は発生しません。 ディレクトリを作成したユーザ ID だけが、このディレクトリに対して内容を読み出したり、書き込んだり、検索したりすることができます。
mkdtemp()
のユーザは用済みになった時に一時ディレクトリとその中身を削除しなければなりません。prefix, suffix, dir 引数は
mkstemp()
関数のものと同じです。mkdtemp()
returns the absolute pathname of the new directory if dir isNone
or is an absolute path. If dir is a relative path,mkdtemp()
returns a relative path on Python 3.11 and lower. However, on 3.12 it will return an absolute path in all situations.引数
fullpath
を指定して 監査イベントtempfile.mkdtemp
を送出します。バージョン 3.5 で変更: suffix、prefix、dir は bytes の返り値を得るために bytes で渡すことが出来ます。 それ以前は str のみ許されていました。 適切なデフォルト値を使用するよう、suffix と prefix は
None
を受け入れ、デフォルトにするようになりました。バージョン 3.6 で変更: dir パラメタが path-like object を受け付けるようになりました。
- tempfile.gettempdir()¶
一時ファイルに用いられるディレクトリの名前を返します。 これはモジュール内の全ての関数の dir 引数のデフォルト値を定義します。
Python は呼び出したユーザがファイルを作ることの出来るディレクトリを検索するのに標準的なリストを使用します。 そのリストは:
環境変数
TMPDIR
で与えられているディレクトリ名。環境変数
TEMP
で与えられているディレクトリ名。環境変数
TMP
で与えられているディレクトリ名。プラットフォーム依存の場所:
Windows ではディレクトリ
C:\TEMP
、C:\TMP
、\TEMP
、および\TMP
の順。その他の全てのプラットフォームでは、
/tmp
、/var/tmp
、および/usr/tmp
の順。
最後の手段として、現在の作業ディレクトリ。
この検索の結果はキャッシュされます。以下の
tempdir
の記述を参照してください。バージョン 3.10 で変更: Always returns a str. Previously it would return any
tempdir
value regardless of type so long as it was notNone
.
- tempfile.gettempdirb()¶
gettempdir()
と同じですが返り値は bytesです。バージョン 3.5 で追加.
- tempfile.gettempprefix()¶
一時ファイルを生成する際に使われるファイル名の接頭辞を返します。 これにはディレクトリ部は含まれません。
- tempfile.gettempprefixb()¶
gettempprefix()
と同じですが返り値は bytes です。バージョン 3.5 で追加.
The module uses a global variable to store the name of the directory
used for temporary files returned by gettempdir()
. It can be
set directly to override the selection process, but this is discouraged.
All functions in this module take a dir argument which can be used
to specify the directory. This is the recommended approach that does
not surprise other unsuspecting code by changing global API behavior.
- tempfile.tempdir¶
When set to a value other than
None
, this variable defines the default value for the dir argument to the functions defined in this module, including its type, bytes or str. It cannot be a path-like object.tempdir
が (デフォルトの)None
の場合、gettempprefix()
を除く上記のいずれかの関数を呼び出す際は常にgettempdir()
で述べられているアルゴリズムによって初期化されます。注釈
Beware that if you set
tempdir
to a bytes value, there is a nasty side effect: The global default return type ofmkstemp()
andmkdtemp()
changes to bytes when no explicitprefix
,suffix
, ordir
arguments of type str are supplied. Please do not write code expecting or depending on this. This awkward behavior is maintained for compatibility with the historical implementation.
使用例¶
tempfile
モジュールの典型的な使用法のいくつかの例を挙げます:
>>> import tempfile
# create a temporary file and write some data to it
>>> fp = tempfile.TemporaryFile()
>>> fp.write(b'Hello world!')
# read data from file
>>> fp.seek(0)
>>> fp.read()
b'Hello world!'
# close the file, it will be removed
>>> fp.close()
# create a temporary file using a context manager
>>> with tempfile.TemporaryFile() as fp:
... fp.write(b'Hello world!')
... fp.seek(0)
... fp.read()
b'Hello world!'
>>>
# file is now closed and removed
# create a temporary directory using the context manager
>>> with tempfile.TemporaryDirectory() as tmpdirname:
... print('created temporary directory', tmpdirname)
>>>
# directory and contents have been removed
非推奨の関数と変数¶
一時ファイルを作成する歴史的な手法は、まず mktemp()
関数でファイル名を作り、その名前を使ってファイルを作成するというものでした。
残念ながらこの方法は安全ではありません。
なぜなら、mktemp()
の呼び出しと最初のプロセスが続いてファイル作成を試みる間に、異なるプロセスがその名前でファイルを同時に作成するかもしれないからです。
解決策は二つのステップを同時に行い、ファイルをすぐに作成するというものです。
この方法は mkstemp()
や上述している他の関数で使用されています。
- tempfile.mktemp(suffix='', prefix='tmp', dir=None)¶
バージョン 2.3 で非推奨: 代わりに
mkstemp()
を使って下さい。呼び出し時には存在しなかった、ファイルの絶対パス名を返します。 prefix、suffix、dir 引数は
mkstemp()
のものと似ていますが、bytes のファイル名、suffix=None
、そしてprefix=None
がサポートされていない点で異なります。警告
この関数を使うとプログラムのセキュリティホールになる可能性があります。この関数がファイル名を返した後、あなたがそのファイル名を使って次に何かをしようとする段階に至る前に、誰か他の人間があなたを出し抜くことができてしまいます。
mktemp()
の利用は、NamedTemporaryFile()
にdelete=False
引数を渡すことで、簡単に置き換えることができます:>>> f = NamedTemporaryFile(delete=False) >>> f.name '/tmp/tmptjujjt' >>> f.write(b"Hello World!\n") 13 >>> f.close() >>> os.unlink(f.name) >>> os.path.exists(f.name) False