以下のようなデータから、まずnumberをキーとして辞書を作成した後、さらにidをキーとして辞書を作成しました。
number,id,value
1,1,1
1,1,2
1,2,3
1,2,4
2,3,5
2,3,6
2,4,7
2,4,8
3,5,9
3,5,10
3,6,11
3,6,12
python
1 2filepath = 'dm.csv' 3 4 5with open(filepath) as f: 6 next(f) 7 data2=[] 8 9 for line in f: 10 line = line.replace('\n','') 11 data = line.split(',') 12 data2.append(data) 13 14 15data={} 16for i in data2: 17 a=data.get(i[0],[]) 18 a.append(i) 19 data[i[0]]=a 20 21data0={} 22for k,v in data.items(): 23 for i in v: 24 d=data0.get(k,{}) 25 data0[k]=d 26 b=data0[k].get(i[1],[]) 27 b.append(i) 28 data0[k][i[1]]=b 29 30print(data0) 31
実行結果は以下のようになりました。
PYTHON
1{'1': {'1': [['1', '1', '1'], ['1', '1', '2']], '2': [['1', '2', '3'], ['1', '2', '4']]}, '2': {'3': [['2', '3', '5'], ['2', '3', '6']], '4': [['2', '4', '7'], ['2', '4', '8']]}, '3': {'5': [['3', '5', '9'], ['3', '5', '10']], '6': [['3', '6', '11'], ['3', '6', '12']]}}
このdata0をfor文を回してnumber、idごとのvalueの平均値を算出する方法をご教示いただきたいです。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。