MochiuWiki : SUSE, EC, PCB
案内
メインページ
最近の更新
おまかせ表示
MediaWiki についてのヘルプ
ツール
リンク元
関連ページの更新状況
特別ページ
ページ情報
We ask for
Donations
検索
個人用ツール
ログイン
Toggle dark mode
名前空間
ページ
議論
表示
閲覧
ソースを閲覧
履歴を表示
インストール - Pythonのソースを表示
提供: MochiuWiki : SUSE, EC, PCB
←
インストール - Python
あなたには「このページの編集」を行う権限がありません。理由は以下の通りです:
この操作は、次のグループのいずれかに属する利用者のみが実行できます:
管理者
、new-group。
このページのソースの閲覧やコピーができます。
== Pythonのダウンロード == [https://www.python.org/downloads/ こちらの公式サイト]から、Pythonのソースコードをダウンロードする。<br> 最新のPythonを導入する場合、"Latest Python 3 Release - Python <バージョン>"を選択する。<br> または、以下のコマンドを実行してダウンロードする。<br> mkdir -p /<Pythonのインストールディレクトリ>/Python_<バージョン> wget [https://www.python.org/ftp/python/3.8.6/Python-3.8.6.tar.xz https://www.python.org/ftp/python/x.x.x/Python-x.x.x.tar.xz] <br><br> == Pythonのインストール == ==== CentOS / SUSE ==== ここでは、Pythonをホームディレクトリにインストールする。<br> <br> Pythonのビルドに必要なライブラリをインストールする。<br> # 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 <br> # まず、以下のディレクトリを作成する。<br><span style="color:#CC0000"><u>--enable-sharedオプションを付加する場合は、必ず、lib64ディレクトリも作成すること。</u></span> #: <code>mkdir -p /<Pythonのインストールディレクトリ>/lib64</code> # ダウンロードしたファイルを解凍するため、以下のコマンドを実行する。 #: <code>tar xf Python-<バージョン>.tar.xz</code> # 解凍したディレクトリに移動して、コンパイル用のディレクトリを作成する。 #: <code>cd Python-<バージョン> && mkdir build</code> # 次に、Makefileを生成するため、以下のコマンドを実行する。<br><br>Pythonを共有ライブラリ付きでインストールするには、<code>--enable-shared</code>オプションを付加する。<br><code>rpath</code>を指定する理由は、ダイナミックリンクを行う側に、リンクするlibpythonX.X.soの場所をフルパスで記憶させるためである。 #: <code>../configure --enable-optimizations --enable-shared --prefix=<Pythonのインストールディレクトリ> \</code><br><code>LDFLAGS="-Wl,-rpath /<Pythonのインストールディレクトリ>/lib64"</code> # Pythonのソースコードのコンパイルを行う。(<code>-j $(nproc)</code>オプションを使用することで、ジョブ数を増加させて高速処理を行う) #: <code>make -j $(nproc)</code> # コンパイル完了後、インストールを行う。 #* configureスクリプトで--prefixオプションを指定する場合 #*: <code>make install</code> #* configureスクリプトで--prefixオプションを指定しない場合 #*: <code>make altinstall</code> # 以下のディレクトリにシンボリックリンクを作成する。 #: <code>ln -s /<Pythonのインストールディレクトリ>/lib64/python<バージョン>/lib-dynload/ /<Pythonのインストールディレクトリ>/lib/python<バージョン>/</code> # 必要ならば、.profileファイルまたは.bashrcファイルに、以下のような環境変数パスを追記する。 #: <code>export PATH="/<Pythonのインストールディレクトリ>/bin:$PATH"</code> #: <code>export LD_LIBRARY_PATH="/<Pythonのインストールディレクトリ>/lib64:$LD_LIBRARY_PATH"</code> <br> <code>--enable-shared</code>オプションを使用する場合の注意点として、<br> python実行ファイルやmod_wsgiライブラリ等のダイナミックリンクを行う側は、libpython3.8.soライブラリに依存するが、<br> libpython3.8.soライブラリを使用しない状態になる可能性がある。<br> <br> 例えば、/usr/local/Python_<バージョン>ディレクトリにインストールして、/usr/local/Python_<バージョン>/bin/pythonを実行する場合、<br> 設定や環境変数によっては、勝手に/usr/lib/libpython3.8.soや/usr/local/Python-3.7.0/lib/libpython3.7.soが使用される危険性がある。<br> <br> 環境変数<code>LD_LIBRARY_PATH</code>を使用することで、読み込むライブラリの場所を指定できるが、<br> 複数のバージョンのPythonを並列して使用する場合、ユーザが手動で環境変数の切り替えを行う必要があり、煩雑になる。<br> <br> <span style="color:#CC0000"><u>そのため、必ず、<code>rpath</code>オプションを指定してPythonをインストールしなければならない。</u></span><br> <br> ==== PinePhone(クロスコンパイル) ==== AArch64向けのPythonをクロスコンパイルするための手順を示す。<br> <span style="color:#C00000;"><u>クロスコンパイルする前に、ホストPCに同じバージョンのPythonがインストールされていることを確認する。</u></span><br> <br> まず、以下のディレクトリを作成する。<br> mkdir -p ~/InstallSoftware/Python_AArch64 <br> ダウンロードしたファイルを解凍するため、以下のコマンドを実行する。 tar xf Python-3.8.6.tar.xz <br> 解凍したディレクトリに移動して、コンパイル用のディレクトリを作成する。 cd Python-3.8.6 && mkdir build <br> AArch64向けにPythonをビルドおよびインストールする。<br> 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 <br><br> == インストールの確認 == ターミナルを起動後、以下のコマンドを実行する。<br> Pythonのバージョン情報が表示されたら正常にインストールされている。<br> python3.8 --version <br><br> == Hello Worldの表示 == 最後に、Pythonを動かす。<br> ターミナルを起動して、以下のコマンドを実行する。<br> python3.8 <br> 最下行に、以下のように表示されていれば、Pythonがコマンドを待っている状態である。<br> >>> <br> その状態で以下の文を実行すると、その下に"Hello World!"と表示される。<br> <syntaxhighlight lang="python"> print("Hello World!") </syntaxhighlight> <br><br> == tkinterのインストール == TCL / TKを使用してGUIを描画する場合は、TCL / TKをインストールする。<br> <br> * パッケージ管理システムを使用する場合 # CentOS sudo yum install tkinter tk-devel # SUSE sudo zypper install python3-tk <br> * 手動でビルドしてインストールする場合 *: [http://www.tcl.tk/software/tcltk/download.html TCL / TKの公式Webサイト]にアクセスして、TCL / TKをダウンロードして解凍する。 *: 解凍したディレクトリのunixディレクトリに移動して、ビルド用ディレクトリを作成する。 ** TCLのインストール **: <code>cd ~/tcl<TCLのバージョン名>/unix && mkdir build && cd build</code> **: <code>../configure --prefix=/home/<ユーザ名>/InstallSoftware/Python/TCL_TK --enable-threads --enable-symbols</code> **: <code>make -j 8</code> **: <code>make install</code> *: <br> ** TKのインストール **: <code>cd ~/tk<TKのバージョン名/unix && mkdir build && cd build</code> **: <code>../configure --prefix=/home/<ユーザ名>/InstallSoftware/Python/TCL_TK \</code> **: <code>--with-tcl=<TCLのビルドディレクトリ 例. /home/<ユーザ名>/Download/tcl<TCLのバージョン名>/unix/build></code> **: <code>make -j 8</code> **: <code>make install</code> <br> tkinterが正常にインストールされたか確認する。<br> # ターミナルで確認する場合 python3 -m tkinter # Pythonインタラクティブで確認する場合 >>> import tkinter >>> tkinter._test() <br> また、Python2.xにtkinterをインストールする場合は、以下のコマンドを実行する。<br> python -m Tkinter <br> tknterが正常にインストールされたか確認する。<br> ターミナルで確認する場合 python -m tkinter Pythonインタラクティブで確認する場合 >>> import tkinter >>> tkinter._test() <br><br> == その他 == ==== PyGObjectのインストール ==== PyGObjectが提供するPythonバインディングを使用して、GTKベースのGUIアプリケーションを実行することができる。<br> これには、PyGObject、GTK、それらの依存関係をインストールする必要がある。<br> <br> * パッケージ管理システムでのインストール *: 以下のコマンドを実行する。 ** CentOS : <code>sudo dnf install python3-gobject gtk3</code> ** SUSE : <code>sudo zypper install python3-gobject python3-gobject-Gdk typelib-1_0-Gtk-3_0 libgtk-3-0</code> *: <br> *: 以下のサンプルコードを実行する。 *: <code>python3 Sample.py</code> <br> * PIPコマンド(PyPI)でのインストール *: GTKと依存関係をビルドするため、以下のコマンドを実行する。 ** CentOS : <code>sudo dnf install gcc gobject-introspection-devel cairo-devel pkg-config python3-devel gtk3</code> ** SUSE : <code>sudo zypper install cairo-devel pkg-config python3-devel gcc gobject-introspection-devel</code> *: <br> *: PycairoとPyGObjectをビルド・インストールするため、以下のコマンドを実行する。 *: <code>pip3 install pycairo</code> *: <code>pip3 install PyGObject</code> *: <br> *: 以下のサンプルコードを実行する。 *: <code>python3 Sample.py</code> <br> <syntaxhighlight lang="python"> 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() </syntaxhighlight> <br><br> __FORCETOC__ [[カテゴリ:Python]][[カテゴリ:RHEL]][[カテゴリ:SUSE]]
インストール - Python
に戻る。
案内
メインページ
最近の更新
おまかせ表示
MediaWiki についてのヘルプ
ツール
リンク元
関連ページの更新状況
特別ページ
ページ情報
We ask for
Donations
Collapse