pyproject.toml の仕様¶
警告
これは 技術的な正式の仕様 です。 pyproject.toml の配慮があってユーザに優しいガイド文書としては、 pyproject.toml を書く を見てください。
pyproject.toml ファイルは、(他のツール類と同様に) パッケージング関係のツール類向けの設定ファイルとして働きます。
pyproject.toml ファイルは TOML で書かれています。現在は、 [build-system] ・ [project] ・ [tool] の3個のテーブルが制定されています。他のテーブル群は将来の使用 (ツールに特有の設定は [tool] テーブルを使うべきです) に備えて予約されています。
ビルドシステムの依存関係を宣言する: [build-system] テーブル¶
[build-system] テーブルでは、プロジェクトのビルドシステムが成功裡に動作するためにインストールされていなくてはならない Python レベルの依存関係をすべて宣言します。
[build-system] テーブルは、ビルドに関連したデータを格納するために使われます。当初は、テーブル内に requires というたったひとつのキーだけが正当、かつ、必須とされました。このキーは、ビルドシステムを実行するのに要求される依存関係を表現する文字列のリストを値に取らなければなりません。このリストの中の文字列は、 バージョン指定子仕様 に従います。
setuptools と共にビルドされるプロジェクトにおける [build-system] の例は:
[build-system]
# Minimum requirements for the build system to execute.
requires = ["setuptools"]
ビルドツール群は、 pyproject.toml ファイルが存在しない場合には、上に例示された設定ファイルをデフォルトのセマンティクスとして使用することを期待されています。
ツール類は、 [build-system] テーブルの存在を (必須のものとして) 要求するべきではありません。 pyproject.toml ファイルにはビルドに関係するデータ以外の設定の詳細を格納して使われることがあるので、 [build-system テーブルが存在していなくても正当なものであると言えます。ファイルは存在するが [build-system] テーブルが欠けている場合、上記のデフォルトの値を使用するべきです。テーブルは存在しているけれども必須のフィールドが欠けている場合には、ツールはこれをエラーであると判断するべきです。
もし、ファイルが存在していて、 [build-system] テーブルが欠落しており、かつ、そのプロジェクトがビルドされるべきであるかに関する明白な指示がない (例えば、 setup.py/setup.cfg またはその他のビルド設定ファイルが欠落しており、かつ、 [project] テーブルが欠落している) のであれば、ツール類は、ユーザに対してエラーを提示することを選択しても構いません。
TOMLファイルからのデータで実例を示す目的だけに使われるようなタイプ特有の表現を提供するためには、後述の JSON スキーマ がデータフォーマットとして適しているでしょう:
{
"$schema": "http://json-schema.org/schema#",
"type": "object",
"additionalProperties": false,
"properties": {
"build-system": {
"type": "object",
"additionalProperties": false,
"properties": {
"requires": {
"type": "array",
"items": {
"type": "string"
}
}
},
"required": ["requires"]
},
"tool": {
"type": "object"
}
}
}
プロジェクトのメタデータを宣言する: [project] テーブル¶
[project] テーブルは、プロジェクトの コアとなるメタデータ を定義します。
メタデータにはふたつの種類があります: 静的 なものと 動的 なものです。静的なメタデータは pyproject.toml ファイルで直接指定されていて、ツール側では指定したり変更したりできません (これは、例えばメタデータが参照するファイルの内容のような、メタデータによって 参照 されるデータを含みます)。動的なメタデータは dynamic キー (この仕様内で後で定義します) を経由して一覧化されていて、ツール側が後から提供することになるでしょう。
[project] テーブルが欠損している場合は、暗黙理に、 ビルドバックエンド が動的にすべてのキーを準備することを意味します。
必ず静的に定義しなければならない必須のキーは次の通り:
名称
必須フィールドだが、静的に指定しても動的に指定しても いずれでも構わない キーは以下の通り:
version
他の全てのキーは必須ではないものと解釈され、これらは静的に指定しても動的にリストしても未指定のままにしていても構いません。
[project] テーブルで許容されるキーの完全なリストは次のとおりです:
著者 <authors>分類詞 <classifiers>依存関係 <dependencies説明 <description>dynamicentry-pointsgui スクリプト <gui-scripts>import-namesimport-namespaceskeywordsライセンスlicense-files保守者 <maintainers>名称optional-dependenciesreadmerequires-pythonscriptsurlsversion
名称¶
TOML 型: 文字列
コアとなるメタデータ フィールドに対応する: 名前 フィールド
プロジェクトの名前。
内部的な一貫性を保つために、ツール側では読み取ったらすぐに、この名前を 正規化 するべきです。
version¶
TOML 型: 文字列
コアとなるメタデータ に対応する: バージョン
バージョン指定子仕様 で定義されるものとしての、プロジェクトのバージョン。
ユーザは正規化済みのバージョンを指定するようにするべきです。
説明 <description>¶
TOML 型: 文字列
コアとなるメタデータ フィールドに対応する: 要約
1行で書かれたプロジェクトに関する説明の要約。これが複数行に渡る場合には、ツールはエラーを発生させても構いません。
readme¶
TOML 型: 文字列またはテーブル
対応する core metadata フィールド: Description and Description-Content-Type
プロジェクトの説明全体 (すなわち README)。
The key accepts either a string or a table. If it is a string then
it is a path relative to pyproject.toml to a text file containing
the full description. Tools MUST assume the file's encoding is UTF-8.
If the file path ends in a case-insensitive .md suffix, then tools
MUST assume the content-type is text/markdown. If the file path
ends in a case-insensitive .rst, then tools MUST assume the
content-type is text/x-rst. If a tool recognizes more extensions
than this specification, it MAY infer the content-type for the user without
specifying this key as dynamic. For all unrecognized suffixes
when a content-type is not provided, tools MUST raise an error.
readme キーはその値がテーブルでも構いません。 file キーは、完全な説明を含むファイルへの pyproject.toml ファイルからの相対パスを表現する文字列を値として持ちます。 text キーは、完全な説明そのものである文字列を値に持ちます。これらのキーは排他的にいずれかひとつしか使えないので、もしメタデータがこれら両方のキーを同時に指定していたらツールはエラーを発生させなければなりません。
readme キーに指定されたテーブルには、完全な説明の content-type を指定する文字列を値とする content-type キーも含まれています。メタデータがこのキーをテーブルの中で指定していない場合には、ツールはエラーを発生させなければなりません。メタデータで charset パラメータが指定されていない場合には、 UTF-8 であるものと想定されます。ツールは各ツールが独自に選択した他のエンコーディングをサポートしても構いません。 コアとなるメタデータ によってサポートされている content-type に変換することができるのであれば、ツールはそのような代替 content-type をサポートしても構いません。そうでなければ、ツールはサポートしていない content-type に対してエラーを発生させなければなりません。
requires-python¶
TOML 型: 文字列
コアとなるメタデータ フィールドに対応する: Requires-Python
プロジェクトが要求する Python のバージョン。
ライセンス¶
TOML 型: 文字列
対応する コアとなるメタデータ フィールド: License-Expression
ライセンス表現 の中で指定されている通りの、正当な SPDX ライセンス表現 であるテキスト文字列。ツール類は、表現文字列の正当性検証と大文字小文字正規化を行うべきです。
このキーは、そのライセンス表現が、 pyproject.toml を使ってビルドバックエンドによって生成されたすべての配布物のどれについてでも、指定されたものと同一である場合に のみ 指定されるべきです。ライセンス表現が異なるのであれば、動的なものとして指定するか、または、全く設定しないか、であるべきです。
伝統的仕様¶
TOML 型: テーブル
対応する core metadata フィールド: License
テーブルには二つのキーのうちのいずれか一つを書くことができます。 file キーは、 pyproject.toml からプロジェクトのライセンス情報を含むファイルへの相対パスを値とする文字列を値に持ちます。ツールの側では、そのファイルのエンコーディングが UTF-8 であるものと仮定しなければなりません。 text キーは、プロジェクトのライセンス条項の文字列を値に取ります。これらのキーは相互に排他的で、従って、両方のキーが指定されているメタデータについてツールの側ではエラーを発生させなければなりません。
テーブルサブキー群では、値としての文字列が PEP 639 によって非推奨にされました。
license-files¶
TOML 型: 文字列の配列
対応する コアとなるメタデータ フィールド: License-File
パッケージと一緒に配布されるライセンスやその他の法律上の通知を含むファイル(群)への、プロジェクトのソースコードツリーの中のパスを、プロジェクトのルートディレクトリ (すなわち、 pyproject.toml 、または、例えば setup.py や setup.cfg その他のような伝統的なプロジェクト設定ファイル群のあるディレクトリ) からの相対パスで指定した配列。
文字列は、 glob のパターン の仕様に倣って、正当な glob パターンを含んでいなければなりません。
パターンは、 pyproject.toml を含むディレクトリからの相対パスで、
ツール類は、ライセンスファイルの内容が正当な UTF-8 エンコードのテキストであると想定しなければならず、また、これを検証して、もし正当でなければエラーを発生させなければなりません。
ビルドツール:
すべての配布物アーカイブ中の、列挙されたパターンにバッチするすべてのファイルを含めなければなりません。
コアとなるメタデータの中の License-File フィールドの下にあるファイルパスで合致したもののそれぞれを列挙しなければなりません。
license-files キーが存在して、かつ、空の配列を値に取っている場合は、ツール類は、ライセンスファイルを一つも含めてはならず、また、エラーを発生させてもいけません。 license-files キーが定義されていなければ、ツール類は、ライセンスファイルをどのように取り扱うかを決定することができます。例えば、ファイルをひとつも含めないことを選択することもできますし、あるいは、独自の論理を用いて配布物中の適切なファイルを発見することもできます。
keywords¶
TOML 型: 文字列の配列
対応する コアとなるメタデータ フィールド: Keywords
プロジェクトに関するキーワード。
分類詞 <classifiers>¶
TOML 型: 文字列の配列
対応する コアとなるメタデータ フィールド: Classifier
プロジェクトに適合する Trove 分類子。
License:: 分類子の使用は非推奨になっており、ツール類は、ユーザに対してその由を通知する警告を発行してもかまいません。 (License-Expression メタデータフィールドに翻訳されるところの) license 文字列値と、 License:: 分類子の両方が使われている場合には、ビルドツール類は、エラーを発生させても構いません。
urls¶
TOML 型: 文字列のキー・バリューを伴うテーブル
対応する コアとなるメタデータ フィールド: Project-URL
キーが URL ラベルで、値が URL そのものであるような URL のテーブル。表示のためにメタデータを処理する時の標準化のルールとよく知られた <well-known> ルールについては、 メタデータ内のよく知られたプロジェクト URL を見てください。
エントリポイント¶
TOML 型: table (
[project.scripts]・[project.gui-scripts]・[project.entry-points])
みっつのテーブルがエントリポイントに関係しています。 [project.scripts] テーブルは、 エントリポイント仕様 の中の console_scripts グループに対応しています。テーブル内のキーはエントリポイントの名前であり、値は参照されるオブジェクトです。
[project.gui-scripts] テーブルは、 エントリポイント仕様 の中の gui_scripts グループに対応します。そのフォーマットは [project.scripts] と同じです。
[project.entry-points] テーブルは、テーブルの集合体です。それぞれのサブテーブルの名前は、ひとつのエントリポイントグループです。キーと値の意味するところは [project.scripts] と同じです。ユーザはネストしたサブテーブルを作ってはならず、代わりにエントリポイントグループを1段階の深さに保つようにしなければなりません。
メタデータの中に [project.entry-points.console_scripts] もしくは [project.entry-points.gui_scripts] というテーブルが定義されている場合は、それぞれ [project.scripts] や [project.gui-scripts] と混同してしまうといけないので、ビルド時のバックエンドがエラーを発生させなければなりません。
依存関係 <dependencies¶
TOML type: Array of dependency specifier strings (
dependencies)Corresponding core metadata field: Requires-Dist
dependencies lists the expected dependencies of the project as an
array of strings.
Each string represents a dependency of the project and MUST be formatted as a valid dependency specifier.
Each string maps directly to a Requires-Dist entry.
Dependencies listed in this array are always considered for installation, but may still contain environment markers that cause them to be skipped in some environments.
optional-dependencies¶
TOML type: table with string keys mapping to arrays of dependency specifier strings (
optional-dependencies)Corresponding core metadata fields: Requires-Dist and Provides-Extra
optional-dependencies is a table where each key specifies
an extra and whose value is an array of strings using the same format as the
dependencies array (the strings in the
arrays must be valid dependency specifiers).
The keys MUST be valid values for Provides-Extra. Each value in the array thus becomes a corresponding Requires-Dist entry for the matching Provides-Extra metadata.
The optionality of these dependencies is recorded by modifying the environment
marker clause on the related Requires-Dist entries to check the extra name.
Optional dependencies are thus only considered for installation if installation
if the associated extra name is requested.
import-names¶
TOML 型: 文字列の配列
対応する core metadata フィールド: Import-Name
インストール時にプロジェクトが排他的に提供したインポートネームを指定する文字列の配列。各文字列は、正当な Python 識別子か空値でなければなりません。インポートネームは、セミコロンと "private" という用語 (例えば "; private") を、セミコロンの前後に空白文字がいくつあっても良い形で、後続させても構いません。
プロジェクトは、そのプロジェクトが排他的に提供した最短のインポートネームをすべて列挙するべきです。最短のネームがドットで区切られたものなら、そのネームからトップレベルに至るすべての中間ネームもまた、 import-names と import-namespaces のいずれか又は両方に適切に列挙されているべきです。例えば、 spam という名前の単一パッケージで複数のサブモジュールを伴っているあるプロジェクトは、 project.import-names=["spam"] だけを列挙することでしょう。 spam.bacon.eggs を列挙しているプロジェクトなら、 spam と spam.bacon についても import-names と import-namespaces の中で適切に考慮しておく必要があるでしょう。すべてのネームを列挙することは、インポートネームに込められた意図が期待通りであることの確認として作動します。同様に、プロジェクトは、それが public であるか private であるかを ; private 修正子を適切に使用してすべてのインポートネームを列挙するべきです。
プロジェクトが同一のネームを import-names と import-namespaces の両方に列挙している場合、ツール類は、曖昧さの故にエラーを発生させなければなりません。
プロジェクトは、プロジェクトがインポートネームを一つも伴わないこと (つまり、配布物ファイルの中には Python モジュールがひとつも存在しないということ) を表現するために、 import-names を空の配列に設定しても構いません。
project.dynamic の中のそのキーをユーザが宣言しているなら、ビルド用バックエンドは、その値を動的に計算することをサポートしても構いません。
例:
[project]
name = "pillow"
import-names = ["PIL"]
[project]
name = "myproject"
import-names = ["mypackage", "_private_module ; private"]
import-namespaces¶
TOML 型: 文字列の配列
対応する コアとなるメタデータ フィールド: Import-Namespace
インストール時にプロジェクトが非排他的に提供したインポートネームを指定する文字列の配列。各文字列は、正当な Python 識別子でなければなりません。インポートネームは、セミコロンの前後には任意の量の空白文字があっても構わないという形で、セミコロンと "private" という用語をその後ろに伴っても構いません (例えば "; private")。 import-names とは異なって、 import-namespaces は空の配列であってはいけません。
プロジェクトは、そのプロジェクトによって排他的に提供された最短インポートネームをすべて列挙するべきです。最短ネームのいずれかがドットで区切られたネームであれば、そのネームからトップレベルのネームに至る中間のネームは、すべて、 import-names と import-namespaces のいずれかまたは両方に適切に列挙されているべきです。
このフィールドは、複数のプロジェクトが同一のインポート名前空間に貢献することができるような名前空間パッケージのために使用されます。 import-namespaces に同じインポートネームを列挙しているプロジェクト群を、それぞれ互いに隠蔽してしまうことなしに一緒にインストールすることができます。
プロジェクトが同一のネームを import-names と import-namespaces の両方に列挙している場合、ツール類は、曖昧さの故にエラーを発生させなければなりません。
project.dynamic の中のそのキーをユーザが宣言しているなら、ビルド用バックエンドは、その値を動的に計算することをサポートしても構いません。
例:
[project]
name = "zope-interface"
import-namespaces = ["zope"]
import-names = ["zope.interface"]
dynamic¶
TOML 型: 文字列の配列
コアとなるメタデータ フィールドに対応する: ダイナミック フィールド
この PEP に列挙されたキーのどれを意図的に指定しないままにすることで他のツールが動的にそのようなメタデータを準備することができる/しようとするかを規定します。後述するツールによる設定に比較して、どのメタデータが目的を持って未指定にされていて未指定のままであることを期待されているのかについて明確に描き出します。
ビルド用のバックエンドは、静的に指定されたメタデータ (つまり
dynamic内に列挙されたキーではないメタデータ) を尊重しなければなりません。メタデータで
dynamic内にnameが指定されている場合には、ビルド用バックエンドがエラーを発生させなければなりません。コアとなるメタデータ の仕様において、あるキーが "必須である" ものとして挙げられている場合には、メタデータはそのキーを静的に指定するか、または、
dynamic内に指定するかしなければなりません (どちらでもない場合にはビルドバックエンドがエラーを発生させなければなりません、すなわち、必須のフィールドが[project]テーブルの中にどんな形でも存在していないということは不可能であるべきです)。コアとなるメタデータ の仕様で、あるキーを "必須ではない" ものとして挙げている場合には、後でビルド用バックエンドがそのキー用のデータを提供するという期待が持てるのであればメタデータではそのキーを
dynamicの中に挙げても構いません。メタデータ内で、あるキーが静的に指定されていて、かつ、
dynamicにも挙げてある場合には、ビルド用バックエンドはエラーを発生させなければなりません。メタデータ内で、あるキーを
dynamicの中に挙げなかった場合は、ビルド用バックエンドがユーザに代わって必要なメタデータを挿入することはできません (すなわち、ツールがメタデータを挿入できるのはdynamicの中だけであり、かつ、ユーザがそうするようにオプトインしていなければならないということです) 。あるキーが
dynamicの中で指定されたメタデータで、しかし、ビルド用バックエンドがそこに挿入するべきデータを決定することができない時は、ビルド用バックエンドはエラーを発生させなければなりません (正確な値であると判断した場合はデータを省略することが許容されます) 。
任意のツールの設定: [tool] テーブル¶
[tool] テーブルは、ビルドツールに限らずその Python プロジェクトに関係するツールであれば何であっても、 [tool] 内のサブテーブルを使う限りはユーザが設定データを指定することができるもので、例えば flit ツールならその設定を [tool.flit] に格納しておくでしょう。
tool.* という名前空間の中に名称を確保するには、他のプロジェクトが同じサブテーブルを使おうと試みて衝突してしまうようなことにならないようにするメカニズムが必要です。我々のルールは、あるプロジェクトが Cheeseshop/PyPI に $NAME というエントリを保有している場合、その場合に限って、 tool.$NAME なるサブテーブルを使うことができるというものです。
歴史¶
2016年5月: PEP 518 を通じて、
pyproject.tomlファイルの初期の仕様、つまり、[build-system]がrequiresキーと[tool]テーブルしか含んでいないものが承認されました。2020年11月: PEP 621 を通じて、
[project]テーブルの仕様が承認されました。2024年12月: PEP 639 を通じて、
licenseキーが再定義され、license-filesキーが追加され、License::分類子が非推奨になりました。2025年9月:
licenseキーが、pyproject.tomlファイルから生成されたすべての配布物のファイル群に適用されることが明確化されました。2025年10月: PEP 794 を通じて
import-namesキーとimport-namespacesキーが追加されました。January 2026: Replaced outdated direct reference to PEP 508 with a reference to 依存関係指定子.