mirror of
https://github.com/red-data-tools/YouPlot.git
synced 2025-09-19 19:08:07 +08:00
Compare commits
10 Commits
Author | SHA1 | Date | |
---|---|---|---|
![]() |
87a8af4957 | ||
![]() |
09271ab6c3 | ||
![]() |
0110b70936 | ||
![]() |
9859cd0213 | ||
![]() |
cb43796e3f | ||
![]() |
958ce45635 | ||
![]() |
203e48e0ed | ||
![]() |
155a0821d3 | ||
![]() |
4a49711d57 | ||
![]() |
e69d1caed7 |
@@ -5,7 +5,7 @@
|
||||
|
||||
Create ASCII charts on the terminal with data from standard streams in the pipeline.
|
||||
|
||||
:bar_chart: Powered by [UnicodePlot](https://github.com/kojix2/uplot)
|
||||
:bar_chart: Powered by [UnicodePlot](https://github.com/red-data-tools/unicode_plot.rb)
|
||||
|
||||
:construction: Under development
|
||||
|
||||
|
43
lib/uplot.rb
43
lib/uplot.rb
@@ -1,46 +1,7 @@
|
||||
require 'uplot/version'
|
||||
require 'unicode_plot'
|
||||
require 'optparse'
|
||||
require 'uplot/version'
|
||||
require 'uplot/command.rb'
|
||||
|
||||
module Uplot
|
||||
class Command
|
||||
def initialize(argv)
|
||||
@params = {}
|
||||
@ptype = nil
|
||||
parse_options(argv)
|
||||
end
|
||||
|
||||
def parse_options(argv)
|
||||
parser = OptionParser.new
|
||||
parser.order!(argv)
|
||||
@ptype = argv.shift
|
||||
|
||||
subparsers = Hash.new do |_h, k|
|
||||
warn "no such subcommand: #{k}"
|
||||
exit 1
|
||||
end
|
||||
|
||||
subparsers['hist'] = OptionParser.new.tap do |sub|
|
||||
sub.on('--nbins VAL') { |v| @params[:nbins] = v.to_i }
|
||||
sub.on('-p') { |v| @params[:p] = v }
|
||||
end
|
||||
|
||||
subparsers[@ptype].parse!(argv) unless argv.empty?
|
||||
end
|
||||
|
||||
def run
|
||||
input_lines = readlines.map(&:chomp)
|
||||
case @ptype
|
||||
when 'hist', 'histogram'
|
||||
histogram(input_lines).render
|
||||
end
|
||||
|
||||
puts input_lines if @params[:p]
|
||||
end
|
||||
|
||||
def histogram(input_lines)
|
||||
series = input_lines.map(&:to_f)
|
||||
UnicodePlot.histogram(series, nbins: @params[:nbins])
|
||||
end
|
||||
end
|
||||
end
|
||||
|
92
lib/uplot/command.rb
Normal file
92
lib/uplot/command.rb
Normal file
@@ -0,0 +1,92 @@
|
||||
module Uplot
|
||||
class Command
|
||||
def initialize(argv)
|
||||
@params = {}
|
||||
@ptype = nil
|
||||
parse_options(argv)
|
||||
end
|
||||
|
||||
def opt_new
|
||||
OptionParser.new do |opt|
|
||||
opt.on('-o', '--output', TrueClass) { |v| @output = v }
|
||||
opt.on('-t', '--title VAL', String) { |v| @params[:title] = v }
|
||||
opt.on('-w', '--width VAL', Numeric) { |v| @params[:width] = v }
|
||||
opt.on('-h', '--height VAL', Numeric) { |v| @params[:height] = v }
|
||||
opt.on('-b', '--border VAL', Numeric) { |v| @params[:border] = v }
|
||||
opt.on('-m', '--margin VAL', Numeric) { |v| @params[:margin] = v }
|
||||
opt.on('-p', '--padding VAL', Numeric) { |v| @params[:padding] = v }
|
||||
opt.on('-l', '--labels', TrueClass) { |v| @params[:labels] = v }
|
||||
end
|
||||
end
|
||||
|
||||
def parse_options(argv)
|
||||
main_parser = opt_new
|
||||
parsers = {}
|
||||
parsers['hist'] = opt_new.on('--nbins VAL', Numeric) { |v| @params[:nbins] = v }
|
||||
parsers['histogram'] = parsers['hist']
|
||||
parsers['line'] = opt_new
|
||||
parsers['lineplot'] = parsers['line']
|
||||
parsers['lines'] = opt_new
|
||||
|
||||
main_parser.banner = <<~MSG
|
||||
Usage:\tuplot <command> [options]
|
||||
Command:\t#{parsers.keys.join(' ')}
|
||||
MSG
|
||||
main_parser.order!(argv)
|
||||
@ptype = argv.shift
|
||||
|
||||
unless parsers.has_key?(@ptype)
|
||||
warn "unrecognized command '#{@ptype}'"
|
||||
exit 1
|
||||
end
|
||||
parser = parsers[@ptype]
|
||||
parser.parse!(argv) unless argv.empty?
|
||||
end
|
||||
|
||||
def run
|
||||
# Sometimes the input file does not end with a newline code.
|
||||
while input = Kernel.gets(nil)
|
||||
input_lines = input.split(/\R/)
|
||||
case @ptype
|
||||
when 'hist', 'histogram'
|
||||
histogram(input_lines)
|
||||
when 'line', 'lineplot'
|
||||
line(input_lines)
|
||||
when 'lines'
|
||||
lines(input_lines)
|
||||
end.render($stderr)
|
||||
|
||||
print input if @output
|
||||
end
|
||||
end
|
||||
|
||||
def histogram(input_lines)
|
||||
series = input_lines.map(&:to_f)
|
||||
UnicodePlot.histogram(series, **@params.compact)
|
||||
end
|
||||
|
||||
def line(input_lines)
|
||||
x = []
|
||||
y = []
|
||||
input_lines.each_with_index do |l, i|
|
||||
x[i], y[i] = l.split("\t")[0..1].map(&:to_f)
|
||||
end
|
||||
UnicodePlot.lineplot(x, y, **@params.compact)
|
||||
end
|
||||
|
||||
def lines(input_lines)
|
||||
n_cols = input_lines[0].split("\t").size
|
||||
cols = Array.new(n_cols) { [] }
|
||||
input_lines.each_with_index do |row, i|
|
||||
row.split("\t").each_with_index do |v, j|
|
||||
cols[j][i] = v.to_f
|
||||
end
|
||||
end
|
||||
plot = UnicodePlot.lineplot(cols[0], cols[1], **@params.compact)
|
||||
2.upto(n_cols - 1) do |i|
|
||||
UnicodePlot.lineplot!(plot, cols[0], cols[i])
|
||||
end
|
||||
plot
|
||||
end
|
||||
end
|
||||
end
|
@@ -1,3 +1,3 @@
|
||||
module Uplot
|
||||
VERSION = '0.1.0'.freeze
|
||||
VERSION = '0.1.1'.freeze
|
||||
end
|
||||
|
Reference in New Issue
Block a user