我的代码库包含prepend_before_action:authenticate_api_user等回调函数!before_action:authenticate_api_v1_user!这两者有什么区别?
我正在使用 ruby Axlsx gem 在 xlsx 中写入我的客户帐户数据。现在我将“ Dr”字符串附加到所有借方金额,这将金额作为字符串,例如“1000 Dr”。我想附加“dr”,但金额仍然应该是一个整数,并且Excel应该在选中列时在底部提供总和。
我在做什么,请注意,即使在选择时,excel 也会在右下角显示 sum = 0:-

我在做什么,请注意单元格在选择时仍然是一个字符串(880 Dr 应该在选择单元格时变为 880.00):-
我想要做的是,excel 应该显示所选列的总和,如右下角 sum=1957.00 Dr 中的 excel 所示:-
我想要做的是,双击时单元格应该转换为数字(选择时 1341.00 Dr 已变为 1341)但再次取消选择时应该可以看到 Dr:-

Date.commercial 找到一周开始(星期一)的方法在第 53 周不起作用
Date.commercial(2018, 1, 1)
#=> 2018-01-01
Date.commercial(2018, 52, 1)
#=> 2018-12-24
Run Code Online (Sandbox Code Playgroud)
当我尝试在有 53 周的年份中查找第 53 周的星期一时,它会引发错误。
Date.commercial(2018, 53, 1)
# ArgumentError: invalid date
Run Code Online (Sandbox Code Playgroud)
此外,它的定义对我来说也不清楚。就像这两个人的行为如此不同:
Date.commercial(2015, 1, 1)
#=> 2014-12-29
Date.commercial(2016, 1, 1)
#=> 2016-01-04
Run Code Online (Sandbox Code Playgroud)
我认为这是因为Date.commercial()将周数转换为日期的定义与Date.strftime("%W"). 是否有任何方法可以将年份的周数转换为与 一致的星期几Date.strftime("%W"),即 的反向函数Date.strftime("%W")?
我只是迁移了create_supplier迁移,然后才意识到我的一种数据类型是错误的,所以我添加了另一个迁移,如下所示:
class ChangePhoneToStringInSuppliers < ActiveRecord::Migration[5.1]
def change
change_column :suppliers, :phone_no_1, :string
change_column :suppliers, :phone_no_2, :string
end
end
Run Code Online (Sandbox Code Playgroud)
迁移之后,我意识到我还没有推送代码,因此理想情况下,我应该回滚直到create_suppliers迁移并在其中添加更改。回滚ChangePhoneToStringInSuppliers时,出现以下错误:-
This migration uses change_column, which is not automatically reversible.
To make the migration reversible you can either:
1. Define #up and #down methods in place of the #change method.
2. Use the #reversible method to define reversible behavior.
Run Code Online (Sandbox Code Playgroud)
我认为上述错误消息(以及互联网上的其他帖子)中建议的方法可以防止此问题,而可以解决(如果我错了,请纠正我)。现在如何回滚此迁移?
ruby-on-rails database-migration ruby-on-rails-4 ruby-on-rails-5