💨

PythonやPipのインストールディレクトリにuserとlibrary両方に存在する理由

に公開

はじめに

PythonやPipを使用していると、インストールディレクトリが「user」と「library」の両方に存在することがあります。これにはそれぞれの理由があり、適切に理解しておくことでPython環境の管理が容易になります。本記事では、これらのディレクトリが存在する理由とその違いについて詳しく解説します。

Pythonのインストールディレクトリの概要

Pythonは通常、システム全体にインストールされる「グローバルインストール」と、ユーザーごとにインストールされる「ユーザーインストール」の2つの方法でインストールされます。

グローバルインストール

  • 場所: 通常、/usr/local/binC:\Python39などのシステムディレクトリにインストールされます。
  • 特徴: システム全体で使用されるPythonインタープリター。管理者権限が必要です。
  • 用途: すべてのユーザーが共通して使用するPython環境。

ユーザーインストール

  • 場所: 通常、ユーザーのホームディレクトリ内の.localフォルダ(例:~/.local/bin)にインストールされます。
  • 特徴: 特定のユーザーが使用するPythonインタープリター。管理者権限は不要です。
  • 用途: 各ユーザーが個別に管理するPython環境。

Pipのインストールディレクトリの概要

Pipでパッケージをインストールする際にも、グローバルインストールとユーザーインストールの2つの方法があります。

グローバルインストール

  • 場所: システム全体のPythonディレクトリ(例:/usr/local/lib/python3.9/site-packages)。
  • 特徴: システム全体で使用されるパッケージ。管理者権限が必要です。
  • 用途: すべてのユーザーが共通して使用するパッケージ。

ユーザーインストール

  • 場所: ユーザーのホームディレクトリ内のPythonディレクトリ(例:~/.local/lib/python3.9/site-packages)。
  • 特徴: 特定のユーザーが使用するパッケージ。管理者権限は不要です。
  • 用途: 各ユーザーが個別に管理するパッケージ。

インストールディレクトリの選択理由

1. 権限管理の違い

グローバルインストールでは、システム全体に影響を与えるため、管理者権限が必要です。これに対して、ユーザーインストールでは各ユーザーが自分の環境だけを変更できるため、管理者権限が不要です。これにより、複数のユーザーが同じマシンで異なるPython環境を持つことができます。

2. 依存関係の管理

ユーザーインストールを使用することで、各プロジェクトやユーザーごとに異なるパッケージバージョンを管理できます。例えば、プロジェクトAではDjango 2.2を使用し、プロジェクトBではDjango 3.0を使用する場合、ユーザーインストールを利用することでこれらの依存関係を分離できます。

3. 環境の再現性

ユーザーインストールは仮想環境(Virtualenvやvenv)と組み合わせることで、開発環境を他の開発者と共有しやすくなります。仮想環境を使用することで、同じパッケージバージョンと設定を他のマシンでも再現できます。

具体的なコマンド例

グローバルインストール

管理者権限でPipを使用してパッケージをインストールします。

sudo pip install package_name

ユーザーインストール

管理者権限なしで、ユーザーのホームディレクトリにパッケージをインストールします。

pip install --user package_name

仮想環境の作成と使用

ユーザーごとに独立したPython環境を作成し、その環境内でパッケージを管理します。

python -m venv myenv
source myenv/bin/activate  # Windowsでは myenv\Scripts\activate
pip install package_name

サイトからインストールした場合

Pythonを公式サイトからインストールする際、通常はシステム全体(グローバル)にインストールされます。この場合、Python本体や標準ライブラリは/usr/local/binC:\Python39などにインストールされます。ユーザーインストールはオプションとして選択できることが多いですが、通常はデフォルトでシステム全体にインストールされます。

コマンドの実行先

ユーザーが普通にPythonやPipを実行した場合、どちらのインストールディレクトリのものが実行されるかは、PATH環境変数に依存します。通常、システム全体のPythonが優先されますが、ユーザーのホームディレクトリにインストールされたPythonがPATHに含まれている場合は、それが優先されます。

優先順の確認方法

which python
which pip

完全アンインストールの方法

PythonやPipを完全にアンインストールするには、以下のディレクトリからファイルを削除する必要があります。

グローバルインストールのアンインストール

  • Python本体: sudo rm -rf /usr/local/bin/python*
  • Pipパッケージ: sudo rm -rf /usr/local/lib/python3.9/site-packages

ユーザーインストールのアンインストール

  • Python本体: rm -rf ~/.local/bin/python*
  • Pipパッケージ: rm -rf ~/.local/lib/python3.9/site-packages

まとめ

PythonやPipのインストールディレクトリに「user」と「library」の両方が存在する理由は、権限管理や依存関係の管理、環境の再現性を考慮した結果です。ユーザーインストールを活用することで、管理者権限なしで個別の環境を設定でき、仮想環境と組み合わせることで開発効率と再現性を向上させることができます。各プロジェクトやユーザーのニーズに合わせて適切なインストール方法を選択しましょう。また、インストールされたディレクトリに注意し、適切に管理することでトラブルを防ぐことができます。

Discussion