0

私はWindowsで1つのrbファイルを使用しrufus/schedulerています。スクリプトはコンピューターの起動時に実行され、cmdウィンドウで実行されます。

rubyが画面に出力するすべてのものをファイルに記録するにはどうすればよいですか?それでも画面に出力を表示できるようにしたい。したがって、現在の動作に加えてロギングが必要です。

  • Windows764ビット
  • ルビー1.9.3p194(2012-04-20)[i386-mingw32]
4

1 に答える 1

3

コンソールではなくスクリプトが出力をファイルに送信するだけの場合は、IO#reopenstdoutとstderrをリダイレクトするために使用します。

def redirect_console(filename)
  $stdout.reopen(filename,'w')
  $stderr.reopen(filename,'w')
end

redirect_console('/my/console/output/file')

1つ以上の出力ストリームに転送する必要がある場合は、プロキシオブジェクトとmethod_missingを使用してそれらに送信します

class TeeIO
  def initialize(*streams)
    raise ArgumentError, "Can only tee to IO objects" unless streams.all? { |e| e.is_a? IO }
    @streams = streams
  end

  def method_missing(meth, *args)
    # HACK only returns result of first stream
    @streams.map {|io| io.send(meth, *args) }.first
  end

  def respond_to_missing?(meth, include_all)
    @streams.all? {|io| io.respond_to?(meth, include_all) }
  end
end

def tee_console(filename)
  tee_to = File.open(filename, 'w')
  tee_to.sync = true  # flush after each write
  $stdout = TeeIO.new($stdout, tee_to)
  $stderr = TeeIO.new($stderr, tee_to)
end

tee_console('/my/console/output/file')
于 2013-03-20T03:26:43.343 に答える