0

我有这样的数据集

0 268 195
1 353 199
2 318 209
3 268 232
4 370 238
5 326 253
6 246 265
7 372 284
8 313 290
9 258 297
0 268 196
1 353 199
2 318 209
3 268 233
4 370 238
5 325 253
6 246 265
7 372 284
8 313 290
9 258 297

我想将第一列用于标签,将第二列和第三列用于(x,y)图,但是,我想只绘制一个时间标签而不进行迭代。我应该怎么做?

谢谢你的帮助。

4

1 回答 1

2

你想要类似的东西:

plot 'datafile' u 2:3:1 with labels

...我不太确定您所说的“我只想绘制一个没有迭代的时间标签”是什么意思...

在我看来,您只想使用 1 个唯一标签。例如,只有一个标签是0,只有一个标签是1等等。为简单起见,我将使用第一个小 python 脚本:

#test.py
import sys

seen = set()
with open(sys.argv[1]) as f:
    for line in f:
        num,rest = line.split(None,1)
        if num not in seen:
            seen.add(num)
            sys.stdout.write(line)

现在我们可以在 gnuplot 中绘制我们的文件:

plot '< python test.py yourdatafile' u 2:3:1 w labels

这是一个版本,test.py它将平均所有具有相同“值”的标签的位置。

import sys
from collections import defaultdict

d = defaultdict(list)
with open(sys.argv[1]) as f:
    for line in f:
        num,x,y = map(int,line.split())
        d[num].append((x,y))

#now average
for k,v in d.items():
    x,y = zip(*v)
    avg_x = float(sum(x))/len(x)
    avg_y = float(sum(y))/len(y)
    print k,avg_x,avg_y
于 2012-11-09T04:00:07.457 回答