import csv import datetime # 辞書にデータを読み取る date_dict = {} with open("moving_train.csv", "r", newline="") as f: reader = csv.reader(f) for row in reader: date = map(int, row[0].split('/')) date_dict[datetime.date(*date)] = int(row[1]) class Year: def __init__(self, x): self.x = x def month_ave(self): for key in list(date_dict): if datetime.date(self.x, 4, 1) <= key < datetime.date(self.x, 5, 1): pass else: del date_dict[key] total = sum(date_dict.values()) average = 1.0 * total / len(date_dict) print(total, average) if __name__ == '__main__': year_2011 = Year(2011) year_2012 = Year(2012) year_2013 = Year(2013) year_2011.month_ave() year_2012.month_ave() year_2013.month_ave()
お世話になります。以下の手順で作業を行おうとしたところエラーが出ました。
(手順)
・csvから以下のようなデータを取得(データ自体は2011-2015くらいまでございます)
2011/4/1,48
2011/4/2,29
2011/4/3,28
2011/4/4,23
2011/4/5,25
・同じ月で年ごとの平均を計算(例えば、2011年の4月と2012年の4月のデータの平均を計算)
以下のようなエラーが出たのですが、もし理由がわかれば教えてほしいです。
何卒よろしくお願いいたします。
C:\Users.....py" 710 23.666666666666668 Traceback (most recent call last): File "C:/Users/.....py", line 35, in <module> year_2012.month_ave() File "C:/Users/.....py", line 25, in month_ave average = 1.0 * total / len(date_dict) ZeroDivisionError: float division by zero
まだ初心者で本やウェブを見ながら作っているため、トンチンカンなところもあるかと思いますが、何卒よろしくお願いいたします。
回答1件
あなたの回答
tips
プレビュー