2017-02-24 13 views
0

複数の.csvファイルを取り、複数のラインプロットを出力するスクリプトがあります。これらのプロットは、降雨を示しているので棒グラフにしたいと思います。しかし、私はplot.bar.()を働かせることができませんでした。これはこれまで私のために働くコードですが、正しくありません。どんな助け?line chartをmatplotlibのpythonコードfor-loopで棒グラフに変換

import pandas as pd 
import time 
import os 
import matplotlib.pyplot as plt 

files = ['w.pod.csv', 
    't.pod.csv', 
    'r.pod.csv', 
    'n.pod.csv', 
    'm.pod.csv', 
    'k.pod.csv', 
    'j.pod.csv', 
    'h.pod.csv', 
    'g.pod.csv', 
    'c.pod.csv', 
    'b.pod.csv'] 

for f in files: 
    fn = f.split('.')[0] 
    dat = pd.read_csv(f) 
    df0 = dat.loc[:, ['TimeStamp', 'RF']] 
    # Change time format 
    df0["time"] = pd.to_datetime(df0["TimeStamp"]) 
    df0["day"] = df0['time'].map(lambda x: x.day) 
    df0["month"] = df0['time'].map(lambda x: x.month) 
    df0["year"] = df0['time'].map(lambda x: x.year) 
    df0.to_csv('{}_1.csv'.format(fn), na_rep="0") # write to csv 

    # Combine for daily rainfall 
    df1 = pd.read_csv('{}_1.csv'.format(fn), encoding='latin-1', 
        usecols=['day', 'month', 'year', 'RF', 'TimeStamp']) 
    df2 = df1.groupby(['day', 'month', 'year'], as_index=False).sum() 
    df2.to_csv('{}_2.csv'.format(fn), na_rep="0", header=None) # write to csv 

    # parse date 
    df3 = pd.read_csv('{}_2.csv'.format(fn), header=None, index_col='datetime', 
       parse_dates={'datetime': [1,2,3]}, 
       date_parser=lambda x: pd.datetime.strptime(x, '%d %m %Y')) 

    def dt_parse(date_string): 
     dt = pd.datetime.strptime(date_string, '%d %m %Y') 
     return dt 

    # sort datetime 
    df4 = df3.sort() 
    final = df4.reset_index() 

    # rename columns 
    final.columns = ['date', 'bleh', 'rf'] 

    final[['date','rf']].plot() 
    plt.suptitle('{} Rainfall 2015-2016'.format(fn), fontsize=20) 
    plt.xlabel('Date', fontsize=18) 
    plt.ylabel('Rain/mm', fontsize=16) 
    plt.savefig('{}.png'.format(fn)) 

enter image description here

これが私の前の質問の拡張である:Automate making multiple plots in python using several .csv files

答えて

1

使用DataFrame.plot.bar

final[['date','rf']].plot.bar() 

またはDataFrame.plot

final[['date','rf']].plot(kind='bar') 
+0

これは簡単でした!ありがとう!!また、xtickラベルを変更するコードも知っていますか?今は365の日付をすべて入れようとしていますが、軸は詰まっています。 30ティック(日)ごとにラベルを付けるといいでしょう。 – JAG2024

+0

私はあなたがこれを確認することができると思う[回答](http://stackoverflow.com/q/2849286/2901002) – jezrael

+0

ありがとう!私の他の質問をチェックしてください:http://stackoverflow.com/questions/42444020/change-frequency-of-x-axis-tick-label-of-datetime-data-in-python-bar-chart-using – JAG2024

関連する問題