Python

提供: ArchWiki
2016年10月20日 (木) 02:36時点におけるColajam93 (トーク | 投稿記録)による版 (一部同期)
ナビゲーションに移動 検索に移動

関連記事

Wikipedia より:

Python は、広く使用されている汎用のスクリプト言語である。コードのリーダビリティが高くなるように言語が設計されているとされ、その構文のおかげで、Cなどの言語に比べて、より少ないコード行数でプログラムを表現することができるとされている。小規模なプログラムから大規模なプログラムまで、さまざまなプログラムをクリアに書けるように、多くのコードが提供されている。
Python は複数のプログラミングパラダイムをサポートしており、オブジェクト指向、命令型、関数型、手続き型などのスタイルでプログラムを書くことができる。動的型付けであり、自動メモリ管理が可能で、さまざまな領域をカバーする大規模な標準ライブラリを提供している。

インストール

Python 3

Python 3 は Python 言語の最新バージョンであり、Python 2 と互換性がありません。大まかには同じですが、細かいところ、特に辞書や文字列などのオブジェクトの扱い方が大幅に変更されており、非推奨になっていた機能が多数削除されています。また、標準ライブラリが目立たないところで再編成されています。大まかな差異については、Python2orPython3 や Dive into Python 3 の を見て下さい。

最新版の Python 3 をインストールするには、公式リポジトリから python パッケージをインストールしてください。

最新の RC/ベータ版をソースからビルドしたいときは、Python Downloads を訪れて下さい。Arch User RepositoryPKGBUILD も含まれています。RC 版をビルドする場合、バイナリは (デフォルトで) /usr/local/bin/python3.x にインストールされるので注意してください。

Python 2

最新版の Python 2 をインストールするには、公式リポジトリから python2 パッケージをインストールしてください。

Python 2 は Python 3 と上手く共存することができます。このバージョンを実行するときは python2 を指定する必要があります。

Python 2 を必要とするプログラムでは Python 3 の /usr/bin/python ではなく /usr/bin/python2 を指定する必要があります。

それには、プログラムやスクリプトをテキストエディタで開いて一番最初の行を変更してください。

一番最初の行は以下のどちらかになっています:

#!/usr/bin/env python

または:

#!/usr/bin/python

どちらにしても、pythonpython2 に変更することでプログラムは Python 3 ではなく Python 2 を使用するようになります。

スクリプトを変更せずに python2 を強制的に使用させる方法として python2 で明示的にプログラムを呼び出すという方法もあります、例:

$ python2 myScript.py

最後に、スクリプトの呼び出しを制御できない場合、環境を変更する方法があります。この方法はスクリプトが #!/usr/bin/env python を使っている場合のみ動作し、#!/usr/bin/python を使っている場合は動作しません。このトリックは envPATH 変数内の最初に一致したエントリを探すことに依存しています。

まずダミーディレクトリを作成:

$ mkdir ~/bin

そして python から python2 のシンボリックリンクと、設定スクリプトをディレクトリに追加:

$ ln -s /usr/bin/python2 ~/bin/python
$ ln -s /usr/bin/python2-config ~/bin/python-config

最後にあなたの PATH 変数の最初に新しいディレクトリを追加してください:

$ export PATH=~/bin:$PATH
ノート: 上記のコマンドによる環境変数の変更は永続的ではありません。現在のターミナルセッションでのみ有効です。

env によってどの python インタプリタが使われているかを確認するには次のコマンドを使ってください:

$ which python

スクリプトによって呼び出される #!/usr/bin/env python を使用して環境を変更する別の方法として #仮想環境 を使うものがあります。

昔のバージョン

現在のバージョンの Python で動作しないアプリケーションのような、過去の遺物を使用したり、古いバージョンの Python が入っているディストリビューション (例: RHEL 5.x は Python 2.4 が、Ubuntu 12.04 は Python 3.1 が入っています) での Python プログラムの動作をテストするために、AUR から昔のバージョンの Python をインストールすることができます:

2014年7月現在、上流の Python は Python 2.7, 3.2, 3.3, 3.4 だけのセキュリティフィックスをサポートしています。インターネットを使用するアプリケーションや信頼できないコードで古いバージョンを使用するのは危険なので推奨されません。

古いバージョンの Python のモジュールやライブラリは python<version without period> で AUR を検索することで見つけられます。例: 2.6 のモジュールを検索する場合 "python26"。

ウィジェットバインディング

以下のウィジェットツールキットのバインディングが存在します:

  • TkInter — Tk バインディング
http://wiki.python.org/moin/TkInter || 標準モジュール
  • pyQtQt バインディング
http://www.riverbankcomputing.co.uk/software/pyqt/intro || python2-pyqt4 python2-pyqt5 python-pyqt4 python-pyqt5
  • pySideQt バインディング
http://www.pyside.org/ || python2-pyside python-pyside
  • pyGTKGTK+ 2 バインディング
http://www.pygtk.org/ || pygtk
  • PyGObject — GObject Introspection による GTK+ 2/3 バインディング
https://wiki.gnome.org/PyGObject/ || python2-gobject2 python2-gobject python-gobject2 python-gobject
  • wxPython — wxWidgets バインディング
http://wxpython.org/ || wxpython

以上のバインディングを Python で使うには、適当なウィジェットキットをインストールする必要があります。

Tips and tricks

IPython

IPython は Python コマンドラインの強化版です。公式リポジトリでは ipythonipython2 で利用できます。 IPython notebook を利用したい場合、IPython3 notebook には jupyter-notebookを、IPython2 notebook には ipython2-notebook をインストールしてください。

$ jupyter notebook

を実行することでブラウザを開き IPython カーネルを実行することができます。ブラウザ上で notebook を作成するときに python のバージョンを指定することができます。

bpython は Python インタプリタの ncurses インターフェイスです。公式リポジトリでは bpythonbpython2 で利用できます。

仮想環境

Python は他の仮想環境や、システムの Python パッケージに干渉されることなくパッケージをインストールすることのできる隔離された環境を作成するツールを提供しています。特定のアプリケーションで利用される Python インタプリタを変更することもできます。

詳細は Python VirtualEnv を見てください。

Python2 シェルで補完を表示

ノート: この項目は Python2 にのみ関連します。Python 3.4 から タブ補完 はデフォルトで有効になっています。

Python のインタラクティブシェルに以下をコピーしてください:

/usr/bin/python
import rlcompleter
import readline
readline.parse_and_bind("tab: complete")

ソース: [1]

トラブルシューティング

ビルドスクリプトのバージョン問題の対処

Many projects' build scripts assume python to be Python 2, and that would eventually result in an error — typically complaining that print 'foo' is invalid syntax. Luckily, many of them call python from the PATH instead of hardcoding #!/usr/bin/python in the shebang line, and the Python scripts are all contained within the project tree. So, instead of modifying the build scripts manually, there is an easy workaround. Just create /usr/local/bin/python with content like this:

/usr/local/bin/python
#!/bin/bash
script=$(readlink -f -- "$1")
case "$script" in (/path/to/project1/*|/path/to/project2/*|/path/to/project3*)
    exec python2 "$@"
    ;;
esac

exec python3 "$@"

Where /path/to/project1/*|/path/to/project2/*|/path/to/project3* is a list of patterns separated by | matching all project trees.

Don't forget to make it executable:

# chmod +x /usr/local/bin/python

Afterwards scripts within the specified project trees will be run with Python 2.

参照