インストール - Python
Pythonのダウンロード
こちらの公式サイトから、Pythonのソースコードをダウンロードする。
最新のPythonを導入する場合、"Latest Python 3 Release - Python <バージョン>"を選択する。
または、以下のコマンドを実行してダウンロードする。
mkdir -p /<Pythonのインストールディレクトリ>/Python_<バージョン> wget https://www.python.org/ftp/python/x.x.x/Python-x.x.x.tar.xz
Pythonのインストール
CentOS / SUSE
ここでは、Pythonをホームディレクトリにインストールする。
Pythonのビルドに必要なライブラリをインストールする。
# CentOS sudo yum install zlib-devel libffi-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel libuuid-devel xz-devel expat-devel # SUSE sudo zypper install zlib-devel libffi-devel libbz2-devel libopenssl-devel ncurses-devel sqlite3-devel readline-devel tk-devel gdbm-devel libuuid-devel xz-devel libnsl-devel
- まず、以下のディレクトリを作成する。
--enable-sharedオプションを付加する場合は、必ず、lib64ディレクトリも作成すること。mkdir -p /<Pythonのインストールディレクトリ>/lib64
- ダウンロードしたファイルを解凍するため、以下のコマンドを実行する。
tar xf Python-<バージョン>.tar.xz
- 解凍したディレクトリに移動して、コンパイル用のディレクトリを作成する。
cd Python-<バージョン> && mkdir build
- 次に、Makefileを生成するため、以下のコマンドを実行する。
Pythonを共有ライブラリ付きでインストールするには、--enable-shared
オプションを付加する。rpath
を指定する理由は、ダイナミックリンクを行う側に、リンクするlibpythonX.X.soの場所をフルパスで記憶させるためである。../configure --enable-optimizations --enable-shared --prefix=<Pythonのインストールディレクトリ> \
LDFLAGS="-Wl,-rpath /<Pythonのインストールディレクトリ>/lib64"
- Pythonのソースコードのコンパイルを行う。(
-j $(nproc)
オプションを使用することで、ジョブ数を増加させて高速処理を行う)make -j $(nproc)
- コンパイル完了後、インストールを行う。
- configureスクリプトで--prefixオプションを指定する場合
make install
- configureスクリプトで--prefixオプションを指定しない場合
make altinstall
- configureスクリプトで--prefixオプションを指定する場合
- 以下のディレクトリにシンボリックリンクを作成する。
ln -s /<Pythonのインストールディレクトリ>/lib64/python<バージョン>/lib-dynload/ /<Pythonのインストールディレクトリ>/lib/python<バージョン>/
- 必要ならば、.profileファイルまたは.bashrcファイルに、以下のような環境変数パスを追記する。
export PATH="/<Pythonのインストールディレクトリ>/bin:$PATH"
export LD_LIBRARY_PATH="/<Pythonのインストールディレクトリ>/lib64:$LD_LIBRARY_PATH"
--enable-shared
オプションを使用する場合の注意点として、
python実行ファイルやmod_wsgiライブラリ等のダイナミックリンクを行う側は、libpython3.8.soライブラリに依存するが、
libpython3.8.soライブラリを使用しない状態になる可能性がある。
例えば、/usr/local/Python_<バージョン>ディレクトリにインストールして、/usr/local/Python_<バージョン>/bin/pythonを実行する場合、
設定や環境変数によっては、勝手に/usr/lib/libpython3.8.soや/usr/local/Python-3.7.0/lib/libpython3.7.soが使用される危険性がある。
環境変数LD_LIBRARY_PATH
を使用することで、読み込むライブラリの場所を指定できるが、
複数のバージョンのPythonを並列して使用する場合、ユーザが手動で環境変数の切り替えを行う必要があり、煩雑になる。
そのため、必ず、rpath
オプションを指定してPythonをインストールしなければならない。
PinePhone(クロスコンパイル)
AArch64向けのPythonをクロスコンパイルするための手順を示す。
クロスコンパイルする前に、ホストPCに同じバージョンのPythonがインストールされていることを確認する。
まず、以下のディレクトリを作成する。
mkdir -p ~/InstallSoftware/Python_AArch64
ダウンロードしたファイルを解凍するため、以下のコマンドを実行する。
tar xf Python-3.8.6.tar.xz
解凍したディレクトリに移動して、コンパイル用のディレクトリを作成する。
cd Python-3.8.6 && mkdir build
AArch64向けにPythonをビルドおよびインストールする。
set -x -e export HOST_ARCH=aarch64-none-linux-gnu && \ export TOOL_PREFIX=/<GCC AArch64ツールチェインのインストールディレクトリ>/bin/$HOST_ARCH && \ export CC=$TOOL_PREFIX-gcc && \ export CXX=$TOOL_PREFIX-g++ && \ export CPP="$TOOL_PREFIX-g++ -E" && \ export AR=$TOOL_PREFIX-ar && \ export RANLIB=$TOOL_PREFIX-ranlib && \ export LD=$TOOL_PREFIX-ld && \ export READELF=$TOOL_PREFIX-readelf && \ export LDLAST="-lgcov" ac_cv_file__dev_ptmx=no ac_cv_file__dev_ptc=no ac_cv_have_long_long_format=yes \ ../configure --prefix=<一時的にAArch64向けPythonをインストールするディレクトリ> \ --build=x86_64-pc-linux-gnu --host=aarch64-linux-gnu --target=aarch64-linux-gnu \ --disable-ipv6 \ --enable-shared \ --with-ensurepip=yes \ --enable-optimization \ --with-zlib-dir=/usr/lib64 make -j $(nproc) \ BLDSHARED="$TOOL_PREFIX-gcc -shared" \ CROSS-COMPILE=$TOOL_PREFIX- CROSS_COMPILE_TARGET=yes make install \ BLDSHARED="$TOOL_PREFIX-gcc -shared" \ CROSS-COMPILE=$TOOL_PREFIX- CROSS_COMPILE_TARGET=yes
インストールの確認
ターミナルを起動後、以下のコマンドを実行する。
Pythonのバージョン情報が表示されたら正常にインストールされている。
python3.8 --version
Hello Worldの表示
最後に、Pythonを動かす。
ターミナルを起動して、以下のコマンドを実行する。
python3.8
最下行に、以下のように表示されていれば、Pythonがコマンドを待っている状態である。
>>>
その状態で以下の文を実行すると、その下に"Hello World!"と表示される。
print("Hello World!")
tkinterのインストール
TCL / TKを使用してGUIを描画する場合は、TCL / TKをインストールする。
- パッケージ管理システムを使用する場合
# CentOS sudo yum install tkinter tk-devel # SUSE sudo zypper install python3-tk
- 手動でビルドしてインストールする場合
- TCL / TKの公式Webサイトにアクセスして、TCL / TKをダウンロードして解凍する。
- 解凍したディレクトリのunixディレクトリに移動して、ビルド用ディレクトリを作成する。
- TCLのインストール
cd ~/tcl<TCLのバージョン名>/unix && mkdir build && cd build
../configure --prefix=/home/<ユーザ名>/InstallSoftware/Python/TCL_TK --enable-threads --enable-symbols
make -j 8
make install
- TKのインストール
cd ~/tk<TKのバージョン名/unix && mkdir build && cd build
../configure --prefix=/home/<ユーザ名>/InstallSoftware/Python/TCL_TK \
--with-tcl=<TCLのビルドディレクトリ 例. /home/<ユーザ名>/Download/tcl<TCLのバージョン名>/unix/build>
make -j 8
make install
tkinterが正常にインストールされたか確認する。
# ターミナルで確認する場合 python3 -m tkinter # Pythonインタラクティブで確認する場合 >>> import tkinter >>> tkinter._test()
また、Python2.xにtkinterをインストールする場合は、以下のコマンドを実行する。
python -m Tkinter
tknterが正常にインストールされたか確認する。
ターミナルで確認する場合 python -m tkinter Pythonインタラクティブで確認する場合 >>> import tkinter >>> tkinter._test()
その他
PyGObjectのインストール
PyGObjectが提供するPythonバインディングを使用して、GTKベースのGUIアプリケーションを実行することができる。
これには、PyGObject、GTK、それらの依存関係をインストールする必要がある。
- パッケージ管理システムでのインストール
- 以下のコマンドを実行する。
- CentOS :
sudo dnf install python3-gobject gtk3
- SUSE :
sudo zypper install python3-gobject python3-gobject-Gdk typelib-1_0-Gtk-3_0 libgtk-3-0
- 以下のサンプルコードを実行する。
python3 Sample.py
- PIPコマンド(PyPI)でのインストール
- GTKと依存関係をビルドするため、以下のコマンドを実行する。
- CentOS :
sudo dnf install gcc gobject-introspection-devel cairo-devel pkg-config python3-devel gtk3
- SUSE :
sudo zypper install cairo-devel pkg-config python3-devel gcc gobject-introspection-devel
- PycairoとPyGObjectをビルド・インストールするため、以下のコマンドを実行する。
pip3 install pycairo
pip3 install PyGObject
- 以下のサンプルコードを実行する。
python3 Sample.py
import gi
gi.require_version("Gtk", "3.0")
from gi.repository import Gtk
window = Gtk.Window(title="Hello World")
window.show()
window.connect("destroy", Gtk.main_quit)
Gtk.main()