3

我已经安装了 Ramaze(在 Windows XP 上),它建议我还安装 win32console 以在它运行时获得彩色日志输出。

但是,这样做之后,我得到的是转义码而不是颜色,如下所示:

W [2009-04-29 09:02:55 $5064]  WARN | : ←[33mNo explicit root folder found, assuming it is C:/Projects/Ruby/Ramaze/Conferences←[0m
D [2009-04-29 09:02:55 $5064] DEBUG | : ←[34mUsing webrick←[0m
I [2009-04-29 09:02:55 $5064]  INFO | : ←[37mWEBrick 1.3.1←[0m
I [2009-04-29 09:02:55 $5064]  INFO | : ←[37mruby 1.8.6 (2008-08-11) [i386-mswin32]←[0m
D [2009-04-29 09:02:55 $5064] DEBUG | : ←[34mTCPServer.new(0.0.0.0, 7000)←[0m
D [2009-04-29 09:02:55 $5064] DEBUG | : ←[34mRack::Handler::WEBrick is mounted on /.←[0m
I [2009-04-29 09:02:55 $5064]  INFO | : ←[37mWEBrick::HTTPServer#start: pid=5064 port=7000←[0m

即使在全新安装 Ruby/Ramaze/win32console 时也会发生这种情况

我的设置是:

  • 带有 SP#3 的 Windows XP
  • ruby 1.8.6 (2008-08-11 补丁级别 287) [i386-mswin32]
  • rubygems 版本 1.3.1
  • win32console gem 1.2.0 版

顺便说一句,以下测试程序似乎可以工作,所以我想知道这是否是我机器上的 Ramaze/win32console 问题。

#!/usr/bin/ruby
require 'rubygems'
require 'win32console'

[0, 1, 4, 5, 7].each do |attr|
  puts '----------------------------------------------------------------'
  puts "ESC[#{attr};Foreground;Background"
  30.upto(37) do |fg|
    40.upto(47) do |bg|
      print "\033[#{attr};#{fg};#{bg}m #{fg};#{bg}  "
    end
  puts "\033[0m"
  end
end
4

6 回答 6

1

也许这不是您正在寻找的答案,但我在 Windows 上使用MSYS/MinGW并且它的 bash 正确显示颜色而无需 win32console gem。

于 2009-04-29T09:36:32.333 回答
1

尝试

require 'rubygems'
require 'win32console'
include Win32::Console::ANSI
include Term::ANSIColor
于 2009-09-30T14:14:37.150 回答
0

在 Ramaze 启动之前需要 win32console。

这是因为 Ramaze 及其日志记录机制在 win32console 之前保留了对 stdout 和 stderr 的引用来替换它们。

于 2009-09-30T14:51:00.047 回答
0

尝试在你的 app.rb 中添加这个

require "win32console"
require "Win32/Console/ANSI"
于 2009-04-29T19:26:45.050 回答
0

我认为这是由于您的代码与 Ramaze(或 Innate)中的代码之间的格式字符串不同造成的。

"\e[#{COLOR_CODE[LEVEL_COLOR[severity]]}m#{string}\e[0m"

这扩展为(对于红色,并且“Hello”是字符串):

"\e[31mHello\e[0m"

\e,在 Ruby 中,被转换为\033,所以这不应该给我们带来麻烦:

当然,等价于\033

"\033" == "\e" # => true

主要区别在于 Ramaze 没有指定背景颜色,因为如果它与终端的默认背景对比太大,可能会导致难看的输出。但是,如果您的背景是蓝色、红色、白色或 Ramaze 用于记录的任何其他前景色,它也可能完全不可读,我认为我们应该明确定义背景,并希望这也能解决您的问题窗户问题。

于 2009-04-29T13:49:20.540 回答
0

我刚刚尝试了如何在 WinXP cmd shell 中加载 ANSI 转义码或获取彩色文件列表中的建议,效果很好。

基本上,我抓住了ANSICon,然后运行:

ansicon.exe -I (那是大写的'i')

从它被提取到的 x86 子文件夹中。这安装了 ANSI 颜色代码 DLL 作为之后打开的所有 cmd.exe 窗口的挂钩。哟,瞧 - cmd.exe 中的颜色

于 2010-11-23T14:00:30.830 回答