Ведущие нули в рельсах

У меня есть поля hr и min, оба целых числа в моем приложении. В поле hr, если пользователь вводит "1", я бы хотел, чтобы Rails автоматически поместил его в "01", прежде чем сохранять его в базе данных. Также для поля min, если пользователь вводит "0", он должен быть введен как "00".

Как я могу это сделать?

Ответ 1

Лучше сохранить его как целое число и просто отобразить его, как описано во время выполнения. Каждый язык имеет свой собственный путь к нулям - для Ruby вы можете использовать String # rjust. Этот метод накладывает строку (выравнивается по правому краю) так, что она становится заданной длиной, используя заданный символ заполнения.

str.rjust(integer, padstr=' ') → new_str

Если integer больше длины str, возвращает новый String длины integer с str с правой стороны и дополняется padstr; в противном случае возвращает str.

some_int = 5
some_int.to_s.rjust(2, '0')  # => '05'
some_int.to_s.rjust(5, '0')  # => '00005'

another_int = 150
another_int.to_s.rjust(2, '0') # => '150'
another_int.to_s.rjust(3, '0') # => '150'
another_int.to_s.rjust(5, '0') # => '00150'

Ответ 3

Это также очень удобно:

"%.2d" % integer

Результирующая строка будет иметь 2 символа, а если число меньше двух символов, то в строке

будет присутствовать 0s.

Ответ 4

Вы не можете хранить 01 как целое. Он будет преобразован в 1

Вы можете сохранить его как строку или вы можете показать его как строку "01"

Ответ 5

Мне нравится оператор%, хотя он, кажется, вышел из моды...

2.0.0-p247 :001 > '%02i' % 1
 => "01"
2.0.0-p247 :002 > '%2i' % 1
 => " 1"
2.0.0-p247 :003 > '%-2i' % 1
 => "1 "

Ответ 6

Еще один способ добиться этого - поместить свое целое число во время отображения, используя sprintf:

f = sprintf '%04d', 49
# f = "0049"

Ответ 7

Попробуйте это, и вы можете изменить их в соответствии с

def numeric92(num)
  if num.present?
    if num < 0 && num > -1
      ('-%05d' % num) + '.' + ('%.2f' % num).split('.').last
    else
      ('%06d' % num) + '.' + ('%.2f' % num).split('.').last
    end
  else
    '000000.00'
  end
end