質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

Matplotlib

MatplotlibはPythonのおよび、NumPy用のグラフ描画ライブラリです。多くの場合、IPythonと連携して使われます。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

pandas

Pandasは、PythonでRにおけるデータフレームに似た型を持たせることができるライブラリです。 行列計算の負担が大幅に軽減されるため、Rで行っていた集計作業をPythonでも比較的簡単に行えます。 データ構造を変更したりデータ分析したりするときにも便利です。

Q&A

解決済

1回答

4279閲覧

同フォルダ内の複数のcsvファイルのグラフ化を一括させたいです

toikouya

総合スコア5

CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

Matplotlib

MatplotlibはPythonのおよび、NumPy用のグラフ描画ライブラリです。多くの場合、IPythonと連携して使われます。

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

pandas

Pandasは、PythonでRにおけるデータフレームに似た型を持たせることができるライブラリです。 行列計算の負担が大幅に軽減されるため、Rで行っていた集計作業をPythonでも比較的簡単に行えます。 データ構造を変更したりデータ分析したりするときにも便利です。

0グッド

0クリップ

投稿2020/01/14 16:05

前提・実現したいこと- リスト

csvファイルのデータ(複数)を一括グラフ化、保存
ひとつひとつファイル名を書き換えてやるのは非効率的だと思うので、
よりよい方法を試したいです。

現在pythonを使っています。

発生している問題・エラーメッセージ

ファイル名を共通させたい
複数のファイルにこのプログラムを適用させたい
なるべく少量のコードで済ませたい

該当のソースコード

import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
import matplotlib.ticker as ticker
from pandas.plotting import scatter_matrix
import io

data = pd.read_csv("logtest 11 20191216.csv",encoding="shift-jis")
df_tmp_humid = data.iloc[:, [5]]
df_tmp_humid.plot()
plt.xlim(0, 1440) # (3)x軸の表示範囲
plt.ylim(0, 1023) # (4)y軸の表示範囲
plt.title("logtest 11 20191216 soilmoisture")
plt.xlabel("time",fontsize=20) # (6)x軸ラベル
plt.ylabel("soilmoisture",fontsize=20)# (7)y軸ラベル
plt.show()
plt.savefig("logtest 11 20191216 soilmoisture")
plt.close()

data = pd.read_csv("logtest 11 20191216.csv",encoding="shift-jis")
df_tmp_humid = data.iloc[:, [2]]
df_tmp_humid.plot()
plt.xlim(0, 1440) # (3)x軸の表示範囲
plt.ylim(0, 50000) # (4)y軸の表示範囲
plt.title("logtest 11 20191216 light")
plt.xlabel("time",fontsize=20) # (6)x軸ラベル
plt.ylabel("light",fontsize=20)# (7)y軸ラベル

plt.savefig("logtest 11 20191216 light")
plt.show()
plt.close()

data = pd.read_csv("logtest 11 20191216.csv",encoding="shift-jis")
data.describe()
df = data.iloc[:, [3]]
plt.scatter(data['time'], data['temperature'], s=5, c="b",alpha=0.9)
plt.xlim(0, 1440) # (3)x軸の表示範囲
plt.ylim(0, 40) # (4)y軸の表示範囲
plt.title("logtest 11 20191216 temperature")
plt.xlabel("time",fontsize=20) # (6)x軸ラベル
plt.ylabel("temperature",fontsize=20)# (7)y軸ラベル
plt.savefig("logtest 11 20191216 temperature")
plt.show()
plt.close()

data = pd.read_csv("logtest 11 20191216.csv",encoding="shift-jis")
data.describe()
df = data.iloc[:, [4]]
plt.scatter(data['time'], data['humidity'], s=5, c="b",alpha=0.9)
plt.xlim(0, 1440) # (3)x軸の表示範囲
plt.ylim(0, 100) # (4)y軸の表示範囲
plt.title("logtest 11 20191216 humidity")
plt.xlabel("time",fontsize=20) # (6)x軸ラベル
plt.ylabel("humidity",fontsize=20)# (7)y軸ラベル
plt.savefig("logtest 11 20191216 humidity")
plt.show()
plt.close()

print('グラフ完了')

試したこと

対象のCSVファイルは
「logtest 11 日付.csv」
という基準で名付けています。
日付の部分は20191216~202019 まであります。
このプログラム「graph_all.py」と
同じフォルダに保存されています。

例:csvファイル
date,time,light,temperature,humidity,soilmoisture
2019/1/16,0:00,0,14,69,672
2019/1/16,0:01,0,14,69,669
2019/1/16,0:02,0,0,0,689

の形式です。

補足情報(FW/ツールのバージョンなど)

バージョン: 1.41.1 (user setup)
コミット: 26076a4de974ead31f97692a0d32f90d735645c0

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

jeanbiego

2020/01/15 02:41

「ファイル名を共通させたい 複数のファイルにこのプログラムを適用させたい なるべく少量のコードで済ませたい」 これを、どこまでチャレンジして何がダメだったか具体的に書いたほうが回答が来ると思います。
toikouya

2020/01/15 03:15

File "l:/フォルダ/11/draw_graph all.py", line 15  df = data.iloc[:, [5]] ^ SyntaxError: invalid character in identifier    が主なエラーです。
jeanbiego

2020/01/15 04:07

ここは「質問への追記・修正の依頼」欄ですので、質問欄へ書き込んだほうが良いです。他の方も見やすいので。 なお、コードを書くときはコードの挿入(<code>ボタン)で書いてみて下さい。 さしあたり、グラフ化コードの全体を関数でくくってみて、csvファイルのパスを引数にとって動かしてみてはいかかでしょう。それができたら、引用先のようにfor文で回すだけです。
guest

回答1

0

ベストアンサー

まずは、上記のソースコードですがループ処理により、こんな感じで書けます。
(一部処理を省いておりますが)

Python

1import pandas as pd 2import matplotlib.pyplot as plt 3import matplotlib.ticker as ticker 4 5#date,time,light,temperature,humidity,soilmoisture 6data = pd.read_csv("logtest 11 20191216.csv", 7 encoding="shift-jis", 8 parse_dates={'datetime': ['date','time']}, 9 index_col='datetime') 10 11for col, d in data.iteritems(): 12 if col not in ['temperature','humidity']: 13 d.plot() 14 else: 15 d.plot(marker='o',linestyle='None', color="b",alpha=0.9) 16 plt.title(f"logtest 11 20191216 {col}") 17 plt.show() 18 plt.savefig(f"logtest 11 20191216 {col}.png") 19 plt.close() 20 21print('グラフ完了')

あとは上記の処理をさらにファイルの数だけループ処理するだけです。
このサンプルではでは、data フォルダ内にある csv ファイルを全て読み込んで、output フォルダにグラフを出力します。(前もって output フォルダは作成しておいてください。)

Python

1import as pd 2import matplotlib.pyplot as plt 3import matplotlib.ticker as ticker 4import glob 5import os 6 7for file in glob.glob('data/*.csv'): 8 basename = os.path.basename(file) 9 name = os.path.splitext(basename)[0] 10 11 data = pd.read_csv(file, 12 encoding="shift-jis", 13 parse_dates={'datetime': ['date','time']}, 14 index_col='datetime') 15 16 for col, d in data.iteritems(): 17 if col not in ['temperature','humidity']: 18 d.plot() 19 else: 20 d.plot(marker='o',linestyle='None', color="b",alpha=0.9) 21 plt.title(f"{name} {col}") 22 #plt.show() 23 plt.savefig(os.path.join('output', f"{name} {col}.png")) 24 plt.close()

投稿2020/01/15 11:10

magichan

総合スコア15898

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

toikouya

2020/01/17 06:07

この方法でできました。 ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問