计算gnuplot中csv中的列

时间:2012-11-14 04:46:47

标签: gnuplot

gnuplot中是否有一个函数返回csv文件中的列数? 我在文档中找不到任何内容,也许有人可以为此提出自定义功能?

2 个答案:

答案 0 :(得分:5)

从gnuplot4.6开始,您可以制作一个小黑客脚本来执行此操作。它肯定不是最有效的,但它是纯粹的gnuplot:

#script col_counter.gp
col_count=1
good_data=1
while (good_data){
   stats "$0" u (valid(col_count))
   if ( STATS_max ){
      col_count = col_count+1
   } else {
      col_count = col_count-1
      good_data = 0
   }
}

现在在主脚本中,

call "col_counter.gp" "my_datafile_name"
print col_count   #number of columns is stored in col_count.

这有一些限制 - 例如,如果数据文件中的列完全是非数字的,后跟更多有效的列,则会阻塞它,但我认为它应该适用于许多典型的用例。

print col_count

最后一点,你可以使用环境变量GNUPLOT_LIB,然后你甚至不需要在当前目录中拥有col_counter.gp

答案 1 :(得分:4)

假设这与this question有关,并且 infile.csv 的内容是:

n,John Smith stats,Sam Williams stats,Joe Jackson stats
1,23.4,44.1,35.1 
2,32.1,33.5,38.5 
3,42.0,42.1,42.1 

你可以这样做:

plot.gp

nc = "`awk -F, 'NR == 1 { print NF; exit }' infile.csv`"
set key autotitle columnhead
set datafile separator ','
plot for [i=2:nc] "< sed -r '1 s/,([^ ]+)[^,]+/,\\1/g' infile.csv" using 1:i with lines

请注意,在{Gnuplot中\1内使用时,"需要转义。

输出:

Data file plot