{ "cells": [ { "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ "# Python 入門3\n", "\n", "この回では、ファイル関連の操作を学習する。\n", "\n", "まず、計算結果のファイル保存、ファイルからの読み込みの方法を学ぶ。\n", "\n", "さらに、関数などよく用いる操作をスクリプトファイルとして保存し、それを ノートブック から呼び出す方法について学ぶ。" ] }, { "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ "## ファイルの保存\n", "\n", "以前作成したフィボナッチ数列をファイルに保存する方法を学ぶ。\n", "\n", "Python の変数の内容は、Python を停止したり(Colab を用いる場合はそれを停止したり)、PCの電源を切ると、その内容は破棄される。\n", "しかし、結果をテキストファイルなどで保存しておくと、その結果はPCの電源が切れても残される。\n", "\n", "またテキストファイルにしておくことで、Pythonの環境がないPCやスマートフォンでも内容を確認することができ、\n", "エクセルなど別のソフトウェアで読み込むことも可能となる。" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "### np.savetxt を用いたファイルの保存\n", "\n", "今回は一例として、フィボナッチ数列の計算結果をリストに保存することにする。" ] }, { "cell_type": "code", "execution_count": 2, "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ "[0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233, 377, 610, 987]\n" ] } ], "source": [ "a, b = 0, 1\n", "fibonacci = [a] # 最初の要素のみが入ったリストを用意する。\n", "while b < 1000:\n", " fibonacci.append(b) # リストにbの値を追加する。\n", " a, b = b, a+b # 現在のbの値と、現在のaとbの値から計算したa+bの値をそれぞれ aとbに代入する。\n", "print(fibonacci)" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "計算結果をファイルに保存する方法は、 `numpy` の `savetxt` 関数を用いることである。\n", "\n", "`savetxt` 関数の基本的な使い方は、 `savetxt([ファイル名], [保存する変数])` である。" ] }, { "cell_type": "code", "execution_count": 3, "metadata": {}, "outputs": [], "source": [ "import numpy as np\n", "\n", "np.savetxt('fibonacci.txt', fibonacci)" ] }, { "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ "上記を実行した後、左側のファイルアイコンをクリックし、fibonacci.txt ファイルが作成されていることを確認せよ。\n", "\n", "作成したファイルはipynbファイルと同様に、右クリック>ダウンロードをクリックすることで自身のPCにダウンロードできる。" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "### 課題1\n", "\n", "$$\n", "f(n)=\\log(n!)\n", "$$\n", "\n", "となる $f(n)$ の値を、 $n∈1,...,30$ に対し計算し、`factorial.txt` という名前のファイルに保存せよ。\n", "計算結果をPandAに添付し提出せよ。" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "## ファイルの読み込み\n", "\n", "同様に、実験で得られた結果や、エクセルなど外部プログラムをPyhonで解析したいこともよくある。\n", "その場合、テキストファイルに一度結果を保存しそれをPythonで読み込む方法が簡単である。" ] }, { "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ "### np.loadtxt を用いた実験データの読み込み\n", "\n", "あるバネに重りをかけた時のバネの全長を計測した仮想的な実験結果を想定する。\n", "まず、以下のURLから`young.txt`ファイルをダウンロードする。\n", "(URLを右クリック>「名前を付けてリンクを保存」や「リンク先を別名で保存」をクリックし、ファイルを自身のPCに保存する。)\n", "\n", "URL:\n", "[https://raw.githubusercontent.com/Johokiso-enshu/python_textbook/master/src/young.txt](https://raw.githubusercontent.com/Johokiso-enshu/python_textbook/master/src/young.txt)\n", "\n", "その後、ノートブックと同じフォルダに保存する。\n", "(ipynbファイルをアップロードするときと同じように、左側のファイルリストにおいてアップロードアイコンをクリックし、young.txtを開く。)\n", "\n", "\n", "テキストファイルの内容を確認すると、二列のデータがあることがわかる。\n", "このようなファイルを読み込むのに最も簡単な方法は、`numpy` の `loadtxt` 関数を用いることである。\n", "\n", "`loadtxt` 関数の基本的な使い方は、`loadtxt([ファイル名], unpack=True)` である。" ] }, { "cell_type": "code", "execution_count": 4, "metadata": {}, "outputs": [], "source": [ "weight, length = np.loadtxt('young.txt', unpack=True)" ] }, { "cell_type": "code", "execution_count": 5, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "array([ 0., 10., 20., 50., 100., 150., 200., 300.])" ] }, "execution_count": 5, "metadata": {}, "output_type": "execute_result" } ], "source": [ "weight" ] }, { "cell_type": "code", "execution_count": 6, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "array([ 91.3, 95.4, 96.7, 105. , 115.9, 127.2, 139.6, 162.4])" ] }, "execution_count": 6, "metadata": {}, "output_type": "execute_result" } ], "source": [ "length" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "結果をグラフに表示せよ。" ] }, { "cell_type": "code", "execution_count": 7, "metadata": { "collapsed": true }, "outputs": [], "source": [ "%matplotlib inline\n", "import matplotlib.pyplot as plt" ] }, { "cell_type": "code", "execution_count": 8, "metadata": { "scrolled": true }, "outputs": [ { "data": { "text/plain": [ "[]" ] }, "execution_count": 8, "metadata": {}, "output_type": "execute_result" }, { "data": { "image/png": "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", "text/plain": [ "" ] }, "metadata": {}, "output_type": "display_data" } ], "source": [ "plt.plot(weight, length, 'o')" ] }, { "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ "## コマンドラインからの実行\n", "\n", "### Python スクリプトファイル\n", "\n", "これまでは、Colabのノートブック を用いてプログラム開発を行ってきた。\n", "ColabのノートブックやJupyter-notebook は試行錯誤しながらプログラムの開発する時には便利であるが、\n", "\n", "- 繰り返し用いるプログラム\n", "- 常時運転させるソフトウェア\n", "- GUI 環境のないワークステーション内での計算\n", "\n", "などでは、対話的な操作よりも、スクリプトファイルとして開発する方が望ましい。\n", "\n", "本節では、繰り返し用いる関数をスクリプトファイル化し、\n", "ノートブックから呼び出す方法について学ぶ。\n", "例として、以前開発した2つのベクトルの内積を計算する `list_dot` 関数を\n", "スクリプトファイルとして保存しよう。\n", "注意点は:\n", "\n", "- スクリプトファイル名は、`.py` で終わる必要がある\n", "- スクリプトファイル内で用いるパッケージは全てスクリプトファイル内でimport する必要がある\n", " 例えば、numpy の関数を用いるスクリプトファイルでは、ファイルの冒頭に `import numpy as np`\n", " を記述する必要がある。\n", "- スクリプトファイル内からは、スクリプトファイル外の変数にはアクセスできない\n", "\n", "ことなどである。\n", "\n", "\n", "\n", "### スクリプトファイル内の関数を呼び出す\n", "\n", "\n", "\n", "1. Colabノートブックの画面左に位置するファイルアイコンをクリックし、ファイルリストを表示させる。\n", "2. ファイルリスト中で右クリック>新しいファイルをクリックすると、untitledというファイル名のファイルが作成される。\n", "3. untitledというファイルを右クリック>ファイル名の変更をクリックし、`list_functions.py`というファイル名に変更する。\n", "4. 作成したファイルをダブルクリックすると編集できる。\n", "5. ファイル>保存をクリックするとファイルを保存できる(Windowsならctrl+s、Macならcommand+sのショートカットキーでも保存できる)。\n", "\n", "上で挙げた注意点に気をつけながら以下をファイル中に記述し、保存する。\n", "\n", "----------------------------------\n", "\n", "```Python\n", "def list_dot(x1, x2):\n", " \"\"\"\n", " 2つのリストを受け取り、その内積を計算する関数。\n", " \"\"\"\n", " dot = 0.0\n", " for i in range(len(x1)):\n", " dot += x1[i]*x2[i] # x += y は、x に x+y を代入することを表す。\n", " return dot # return 文で計算した値を返す。\n", "```\n", "\n", "----------------------------------" ] }, { "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ "ここで作成したスクリプトファイルは、別のスクリプトファイルやノートブック中のセルなどから呼び出すことができる。\n", "\n", "呼び出すためには、 `numpy` の関数を呼び出す時のように、`import`文を用いて呼び出しを宣言する。\n", "(なお、ファイル拡張子 `.py` の部分は省略する必要がある)" ] }, { "cell_type": "code", "execution_count": 9, "metadata": { "collapsed": true }, "outputs": [], "source": [ "import list_functions" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "`list_functions` の中に作成した `list_dot` 関数を呼び出すためには、 \n", "`list_functions.list_dot` \n", "というように、`.`に続けて関数名を指定する。" ] }, { "cell_type": "code", "execution_count": 10, "metadata": {}, "outputs": [ { "data": { "text/plain": [ "2.0" ] }, "execution_count": 10, "metadata": {}, "output_type": "execute_result" } ], "source": [ "# [1,1,1] と [0,1,1] の内積を計算させる。\n", "list_functions.list_dot([1,1,1], [0,1,1])" ] }, { "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ "なお、関数名にカーソルを保持することで、関数の中に書いた説明(docstring という)を表示させることができる。\n", "\n", "" ] }, { "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ "**注意点**\n", "\n", "Colabで作成したスクリプトファイルはブラウザを閉じると消去されてしまうため、必要に応じてダウンロードをして自身のPCに保存しておくこと。" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "### 課題2\n", "\n", "2つの行列 A と B の積を計算する関数をスクリプトファイルとして作成せよ。\n", "適当な2つの行列積を、そのスクリプトファイルをインポートすることで実行せよ。\n", "\n", "なお、1つのスクリプトファイルの中には複数の関数を記述することができる。\n", "上記関数を、`list_functions.py` の中に `list_product` という名前で作成せよ。" ] }, { "cell_type": "code", "execution_count": 11, "metadata": { "collapsed": true }, "outputs": [], "source": [ "# 解答をここに記入する" ] }, { "attachments": {}, "cell_type": "markdown", "metadata": {}, "source": [ "## スクリプトファイルの実行\n", "\n", "これまではノートブックを用いてスクリプトを実行してきたが、Python は単体で実行することができる。\n", "といっても、ノートブックに記述したスクリプトを1つのファイルにまとめるだけである。\n", "\n", "上記のlist_dot関数を用いた内積の計算を行うスクリプトファイルを作成するには、\n", "\n", "1. list_functions.py と同じ場所に、適当な名前のファイル(例えば list_dot_script.py)を作成する。\n", "2. 上で作った内容をファイル内に記述する。\n", "具体的には以下のようなものである。\n", "\n", "```python\n", "import list_functions\n", "\n", "print(list_functions.list_dot([1,1,1], [0,1,1]))\n", "```\n", "\n", "3. 以下のコマンドを入力したセルを実行することで、作成したスクリプト(list_doc_script.py)を実行できる。\n", "\n", "```bash\n", "!python list_dot_script.py\n", "```\n", "\n", "(補足)\n", "\n", "自身のPCにPythonがインストールされていれば、コマンドプロンプト上に\n", "```bash\n", "python list_dot_script.py\n", "```\n", "と入力することでlist_doc_script.pyを実行できる。\n" ] }, { "cell_type": "markdown", "metadata": {}, "source": [ "### 課題3\n", "\n", "2つの行列の積を計算するスクリプトファイルを`list_product_script.py` という名前で作成し、実行せよ。\n", "また、実行結果をスクリーンショットに撮り、メール添付せよ。" ] } ], "metadata": { "anaconda-cloud": {}, "kernelspec": { "display_name": "Python 3", "language": "python", "name": "python3" }, "language_info": { "codemirror_mode": { "name": "ipython", "version": 3 }, "file_extension": ".py", "mimetype": "text/x-python", "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", "version": "3.8.5" }, "latex_envs": { "bibliofile": "biblio.bib", "cite_by": "apalike", "current_citInitial": 1, "eqLabelWithNumbers": true, "eqNumInitial": 0 }, "toc": { "toc_cell": false, "toc_number_sections": true, "toc_threshold": 6, "toc_window_display": false } }, "nbformat": 4, "nbformat_minor": 1 }