pythonで自動販売機の月別売上高の集計を行うプログラムを作成したい
<前提>
ファイル'input/report.csv'の中に、自動販売機の売上データが入っている。形式は以下の通り
2014-06-20 10:22:13,コーヒー,120
2014-06-21 18:10:02,オレンジジュース,110
2014-06-28 12:03:40,コーラ,120
2014-07-04 13:47:10,ミネラルウォーター,100
2014-07-08 22:10:28,コーラ,120
2014-07-10 06:55:22,お茶,150
2014-07-12 12:10:40,お茶,150
2014-07-13 10:29:33,コーラ,120
2014-07-13 11:18:08,コーヒー,120
2014-07-14 13:36:59,オレンジジュース,110
=>このファイルを読み込んで、月ごと(6月、7月)に売上金額のを集計し、画面に出力するプログラムを作成する。
先に正解を記載します
python
1from datetime import datetime 2 3sales ={} 4 5with open('input/report.csv', encoding='utf-8') as f: 6 for row in f: 7 date, menu, price = row.rstrip().split(',') 8 solddate = datetime.strptime(date, '%Y-%m-%d %H:%M:%S') 9 if solddate.month not in sales: 10 sales[solddate.month] = 0 11 sales[solddate.month] += int(price) 12 13for key,value in sales.items(): 14 print(key,'月: ', value, sep='')
よくわからない点
9〜11行目の条件分岐について
辞書salesにsolddate.monthが入っていなかったら、値を0とする項目を追加するということでしょうか?
{solddate.month:0, ...}というイメージですか?
条件分岐の外(11行目)でsales[solddate.month]の値にpriceを自己代入しているのも理解できません。
python
1--------------9行目から----------------- 2 3if solddate.month in sales: 4 sales[solddate.month] += int(price) 5else: 6 sales[solddate.month] = 0 7 8--------------以下省略------------------
上のように記述した方が自分の理解としてはわかりやすく、
形式上も綺麗なのにと思ったら異なる実行結果が出てしまいました。
正解の方の条件分岐がなぜ正しく、2つめに記載したコードの条件分岐が何故誤っているのか、
2つめのコードの条件分岐は何をどう分岐しているのか、
初心者にも分かるようご教示いただけるとありがたいです。
回答3件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2018/08/18 13:35