時系列データが記録された 1 GB ファイルを読み取り、2 つの列 (1 つは時間、もう 1 つは数値) を含むリアルタイム グラフを生成する最良の方法は何ですか? ファイルをテーラリングするさまざまな方法があることがわかりました。
質問する
3468 次
3 に答える
7
RRDToolにとっては良い仕事のように思えます。
しかし、Python に固執したい場合は、tail を使用してデータをプログラムにストリーミングします (これは、ファイルが継続的に書き込まれることを前提としています。そうでない場合は、Python の単純な open() が機能します)。
tail -F data.log | python myprogram.py
myprogram.py は次のようになります。
import sys
p = ... # create a pylab plot instance
for line in sys.stdin:
elements = line.split(',') # or whatever separator your file has in it
p.add(element[0], element[1]) # add data to the pylab plot instance
于 2009-11-11T01:07:23.913 に答える
2
John が述べたように、末尾の出力をファイルに入力することができますが、何らかの理由でファイル内のすべてを処理し、多少動的なグラフの例も必要な場合は、ここにあります
import math
import time
import pylab
def getDataTest(filePath):
s = 0
inc = .05
x_list=pylab.arange(0, 5.0, 0.01)
while 1:
s += inc
if abs(s) > 1:
inc=-inc
y_list = []
for x in x_list:
x += s
y = math.cos(2*math.pi*x) * math.exp(-x)
y_list.append(y)
yield x_list, y_list
def tailGen(filePath):
f = open(filePath)
#f.seek(0, 2) # go to end
for line in f: yield line
while 1:
where = f.tell()
line = f.readline()
if line:
yield line
else:
time.sleep(.1)
f.seek(where)
def getData(filePath):
x_list = []
y_list = []
maxCount = 10
for line in tailGen(filePath):
# get required columns
tokens = line.split(",")
if len(tokens) != 2:
continue
x, y = tokens
x_list.append(x)
y_list.append(y)
if len(x_list) > maxCount:
x_list = x_list[-maxCount:]
y_list = x_list[-maxCount:]
yield x_list, y_list
pylab.ion()
pylab.xlabel("X")
pylab.ylabel("Y")
dataGen = getData("plot.txt") # getDataTest("plot.txt") #
x_list, y_list = dataGen.next()
plotData, = pylab.plot(x_list, y_list, 'b')
#pylab.show()
pylab.draw()
for (x_list, y_list) in dataGen:
time.sleep(.1)
plotData, = pylab.plot(x_list, y_list, 'b')
pylab.draw()
そこから要素を拾うことができ、問題を解決できると思います。
于 2009-11-11T04:31:11.187 に答える
2
これは、tail'er、filter (gawk)、およびプロッター (python) の 3 つの部分を持つ UNIX パイプです。
tail -f yourfile.log | gawk '/PCM1/{print $21; fflush();}' | python -u tailplot.py
ここにpythonスクリプトがあります。1 (y) または 2 (xy) 列のデータをフィードできます。を使用しない場合はgawk
、バッファリングを無効にする方法を確認してください。sed -u
例えば。
pa-poca$ cat ~/tailplot.py
import math
import time
import sys
import pylab
pylab.ion()
pylab.xlabel("X")
pylab.ylabel("Y")
x = []
y = []
counter = 1
while True :
line = sys.stdin.readline()
a = line.split()
if len(a) == 2:
x.append(a[0])
y.append(a[1])
elif len(a) == 1:
x.append(counter)
y.append(a[0])
counter = counter + 1
pylab.plot(x, y, 'b')
pylab.draw()
于 2014-10-24T18:32:01.827 に答える