Подтвердить что ты не робот

Есть ли эквивалент для PHP print_r в Ruby/Rails?

В PHP вы можете:

print_r($var) или vardump($var)

который печатает "правдоподобную" информацию о переменной.

Существуют ли эквивалентные функции/помощники для Ruby/Rails?

4b9b3361

Ответ 1

В шаблонах Rails вы можете сделать

<%= debug an_object %>

и он сделает хороший вывод HTML PRE.

Ответ 2

Попробуйте использовать pp. Вам нужно будет потребовать его в скриптах (или в irb, если ваш .irbc этого еще не делает):

require 'pp'

Тогда вы можете "PrettyPrint" создать объект таким образом:

pp object

Ответ 3

Вместо того, чтобы требовать "pp" и используя pp, вы можете просто сделать

p object

Протестированный пример

require 'pp'

class A
  def initialize
    @a = 'somevar'
    @b = [1,2,3]
    @c = {'var' => 'val'}
  end
end

a = A.new
pp a # Gives -> #<A:0x2c6d048 @a="somevar", @b=[1, 2, 3], @c={"var"=>"val"}>
p a # Gives -> #<A:0x2c6d048 @a="somevar", @b=[1, 2, 3], @c={"var"=>"val"}>. No need to require 'pp'

Ответ 4

Здесь помогает метод inspect. Иногда вызов метода to_s для объекта помогает (to_s возвращает строковое представление объекта). Вы также можете запросить methods, local_variables, class_variables, instance_variables, constants и global_variables.

p ['Hello',"G'day",'Bonjour','Hola'].inspect
# >> "[\"Hello\", \"G'day\", \"Bonjour\", \"Hola\"]"

p ['Hello',"G'day",'Bonjour','Hola'].to_s
# >> "HelloG'dayBonjourHola"

p Array.new.methods
# >> ["select", "[]=", "inspect", "compact"...]

monkey = 'baboon'
p local_variables
# >> ["monkey"]

class Something
  def initialize
    @x, @y = 'foo', 'bar'
    @@class_variable = 'gorilla'
  end
end

p Something.class_variables
# >> ["@@class_variable"]

s = Something.new
p s.instance_variables
# >> ["@x", "@y"]

p IO.constants
# >> ["TRUNC", "SEEK_END", "LOCK_SH"...]

p global_variables
# >> ["$-d", "$\"", "$$", "$<", "$_", "$-K"...]

Ответ 5

Я знаю, что это старый пост, но это первое, что Google всплывает при поиске "Ruby эквивалент PHP print_r". Я использую Ruby в режиме командной строки, и на самом деле не очень хороший эквивалент. "pp" подходит для довольно простых структур, но как только вы начинаете вставлять хэши в массивы в хэши в большем количестве массивов, он превращается в беспорядок довольно быстро. Поскольку я не нашел хорошей эмуляции print_r, я написал ее сам. Это достаточно хорошо для моих целей, но не слишком сложно, и я думал, что поделюсь им, чтобы спасти других людей от головной боли. Сравните результат с реальным PHP print_r

def print_r(inHash, *indent)
    @indent = indent.join
    if (inHash.class.to_s == "Hash") then
        print "Hash\n#{@indent}(\n"
        inHash.each { |key, value|
            if (value.class.to_s =~ /Hash/) || (value.class.to_s =~ /Array/) then
                print "#{@indent}    [#{key}] => "
                self.print_r(value, "#{@indent}        ")
            else
                puts "#{@indent}    [#{key}] => #{value}"
            end
        }
        puts "#{@indent})\n"
    elsif (inHash.class.to_s == "Array") then
        print "Array\n#{@indent}(\n"
        inHash.each_with_index { |value,index|
            if (value.class.to_s == "Hash") || (value.class.to_s == "Array") then
                print "#{@indent}    [#{index}] => "
                self.print_r(value, "#{@indent}        ")
            else
                puts "#{@indent}    [#{index}] => #{value}"
            end
        }
        puts "#{@indent})\n"
    end
    #   Pop last indent off
    8.times {@indent.chop!}
end

Вот пример (бесполезный, чтобы показать, почему PHP print_r так хорош):

    carTools =  [ "Socket Set", "Combination Wrenches", "Oil Filter puller", "Brake Compressor" ]
    houseTools =[ "Circular Saw", "Miter Saw", "Drill" ]
    garageItems = Hash["Car1" => "Ford Mustang", "Car2" => "Honda Civic", "Bike1" => "IronHorse"]
    garageItems["Tools"] = Hash["Car Tools" => carTools, "House Tools" => houseTools]
    constructionSupplies = Hash["Plywood" => ["3/4\" T&G Plywood Sheets", "1/2\" Plywood Sheets"],
                                "Boards" => ["2x4s", "2x6s", "Engineered I-Joists"],
                                "Drywall" => ["4x8 1/2\" Sheetrock", "Mesh tape", "Paper tape", "Joint compount"]]
    carParts = Hash["Mustang" => ["Clutch", "Transmission", "3.55 Ring & Pinion Gears", "Differential", "30# Injectors", "Pro-M 77mm MAF"]]
    garageItems["Supplies"] = ["Oil", "WD40", constructionSupplies, carParts, "Brake Fluid"]
    print_r(garageItems)

Вывод print_r (фактически понятный человеку):

    Hash
    (
        [Car1] => Ford Mustang
        [Car2] => Honda Civic
        [Bike1] => IronHorse
        [Tools] => Hash
            (
                [Car Tools] => Array
                    (
                        [0] => Socket Set
                        [1] => Combination Wrenches
                        [2] => Oil Filter puller
                        [3] => Brake Compressor
                    )
                [House Tools] => Array
                    (
                        [0] => Circular Saw
                        [1] => Miter Saw
                        [2] => Drill
                    )
            )
        [Supplies] => Array
            (
                [0] => Oil
                [1] => WD40
                [2] => Hash
                    (
                        [Plywood] => Array
                            (
                                [0] => 3/4" T&G Plywood Sheets
                                [1] => 1/2" Plywood Sheets
                            )
                        [Boards] => Array
                            (
                                [0] => 2x4s
                                [1] => 2x6s
                                [2] => Engineered I-Joists
                            )
                        [Drywall] => Array
                            (
                                [0] => 4x8 1/2" Sheetrock
                                [1] => Mesh tape
                                [2] => Paper tape
                                [3] => Joint compount
                            )
                    )
                [3] => Hash
                    (
                        [Mustang] => Array
                            (
                                [0] => Clutch
                                [1] => Transmission
                                [2] => 3.55 Ring & Pinion Gears
                                [3] => Differential
                                [4] => 30# Injectors
                                [5] => Pro-M 77mm MAF
                            )
                    )
                [4] => Brake Fluid
            )
    )

Ответ 6

Ознакомьтесь с руководством по отладке рельсов: http://guides.rubyonrails.com/debugging_rails_applications.html

подсказки: script/console отлично подходит для использования в контексте вашего приложения script/server --debugger, чтобы запустить сервер с включенным отладчиком, вы можете использовать "debug" в своем коде для взлома в интерактивную оболочку

Ответ 7

Один подход, на который я опишу много, таков:

logger.debug "OBJECT: #{an_object.to_yaml}"

Легко читается, хотя он может стать немного громоздким для больших объектов.

Ответ 8

Предположим, я немного опаздываю на это, но как насчет logger.info [debug | warning]? Используйте это для контроллеров и моделей. Он будет отображаться в ваших файлах журнала (development.log в режиме dev); и вышеупомянутый <%= debug("str: " + str) %> для представлений.

Это не точные ответы на ваши вопросы, но вы также можете использовать script/console для загрузки вашего приложения rails в интерактивный сеанс.

Наконец, вы можете разместить отладчик в строке своего приложения rails, и браузер будет "зависать", когда ваше приложение выполнит эту строку, и вы сможете быть в отладочном сеансе с точной строки, в которой размещен ваш отладчик в исходный код.