応用プログラミング及び実習 2021年度 ex04 †[edit]
notebook のセルを実行していると,たまにセルの番号のところが [*] となったままで反応が返ってこなくなるときがあります.
ありがちな状況と対処法を書いときます
- 単に処理に時間がかかってるだけ → 待てばいい
- input( ) が入力待ってる → 入力欄になんか入力して Enter
- いつまで待ってもだめ → ウィンドウ上部の「■」ボタンを押して,そのセルの実行を強制的に停止させる
ex04kadaiA.ipynb
- 上記のリンク先から notebook ファイルをダウンロードして開く
- そこに記された指示にしたがって notebook を編集・実行して保存
- その notebook ファイルを以下の提出場所へ提出
提出場所: この科目の Moodle コース の「ex04課題A」
- 右のリンク先のファイルを自分の AProg2021 フォルダ/ディレクトリに保存しましょう.: zipdata.txt
- リンクを右クリックして「リンク先を別名で保存」とかそんなん
- このファイルは,文字コード UTF-8 / UNIX改行コードで作成されたテキストファイルです.
Windows環境の一部のソフトウェア(メモ帳など)で開くと,文字コードを変換できなくて化けちゃうことがあります.
- ダウンロードしたファイルを VSCode で開いて内容を確認しておきましょう.
- AProg2021 に,以下の内容のファイル ex04zip.py を作りましょう.
#### AProg2021 第4回課題B
### 関数 readZIP() の定義
# 中身は一部知らないこともあるので,現時点では眺めてふーんって感じでよい
def readZIP(fn):
dZIP = {} # 空のディクショナリを作る
# macOS のひとは,以下の「encoding="utf-8"」の部分はなくても ok
with open(fn, "r", encoding="utf-8") as f: # ファイル名 fn のファイルを読み込みモードで開く
for line in f: # ファイルから1行ずつ読み込んでループ
x, y = line.split() # 空白区切りで分割.1つ目を x に,残り(2つ目)を y に
dZIP[x] = y # キー x, 値 y のペアを登録.x, y とも文字列
return dZIP
# 引数にファイル名を指定して readZIP() を呼ぶ
# 何を引数に指定するかは自分で考えよう.戻り値は郵便番号データのディクショナリ
zip = readZIP( )
# ディクショナリに対する len() は,キーの数を返す
print(len(zip), "件の郵便番号データを読み込みました")
- 上記を1箇所だけ修正(コード中のコメント参照,引数にはダウンロードしたファイルの名前を指定しましょう)して,動作確認しましょう.
- さらにプログラムを修正して, 実行すると次のように郵便番号から住所を検索できるようにしてください
- 動作確認をして間違いがないことを確認したら,以下へ提出してください.提出するのは,ex04zip.py です.
提出場所: この科目の Moodle コース の「ex04課題B」
ex04S (omake) †[edit]
これはおまけ課題です.やらなくても減点はありません.やったら棒茄子?
ex04kadaiS.ipynb
- 上記の notebook を開き,その指示にしたがって編集・実行し,仕上げた notebook ファイルを提出してください
- 期限と提出場所: 1028木の授業終了までに Teams チャットで takataka へ
この課題のねらい:
- Pythonで初歩的なデータ分析を経験してみる
- ネット上のリファレンス等の情報を自分で収集してプログラムを書く経験をする