是否有任何现成的函数可以将驼峰字符串转换为下划线分隔的字符串?
我想要这样的东西:
"CamelCaseString".to_underscore
返回“camel_case_string”。
...
是否有任何现成的函数可以将驼峰字符串转换为下划线分隔的字符串?
我想要这样的东西:
"CamelCaseString".to_underscore
返回“camel_case_string”。
...
Rails 的 ActiveSupport 使用以下命令为字符串添加下划线:
class String
def underscore
self.gsub(/::/, '/').
gsub(/([A-Z]+)([A-Z][a-z])/,'\1_\2').
gsub(/([a-z\d])([A-Z])/,'\1_\2').
tr("-", "_").
downcase
end
end
然后你可以做一些有趣的事情:
"CamelCase".underscore
=> "camel_case"
您可以使用
"CamelCasedName".tableize.singularize
要不就
"CamelCasedName".underscore
两种选择方式都会产生"camel_cased_name"
。您可以在此处查看更多详细信息。
单行 Ruby 实现:
class String
# ruby mutation methods have the expectation to return self if a mutation occurred, nil otherwise. (see http://www.ruby-doc.org/core-1.9.3/String.html#method-i-gsub-21)
def to_underscore!
gsub!(/(.)([A-Z])/,'\1_\2')
downcase!
end
def to_underscore
dup.tap { |s| s.to_underscore! }
end
end
所以"SomeCamelCase".to_underscore # =>"some_camel_case"
有一个名为“下划线”的 Rails 内置方法可以用于此目的
"CamelCaseString".underscore #=> "camel_case_string"
“下划线”方法通常可以被认为是“骆驼化”的逆方法
以下是Rails 的做法:
def underscore(camel_cased_word)
camel_cased_word.to_s.gsub(/::/, '/').
gsub(/([A-Z]+)([A-Z][a-z])/,'\1_\2').
gsub(/([a-z\d])([A-Z])/,'\1_\2').
tr("-", "_").
downcase
end
如果有人在寻找需要将下划线应用于带空格的字符串并希望将它们转换为下划线的情况下,您可以使用类似这样的东西
'your String will be converted To underscore'.parameterize.underscore
#your_string_will_be_converted_to_underscore
或者只是使用 .parameterize('_') 但请记住,这个已被弃用
'your String will be converted To underscore'.parameterize('_')
#your_string_will_be_converted_to_underscore
当您还包含空格时,用于 CamelCases 的短单行线(如果您在中间有一个带有小开头字母的单词,则无法正常工作):
a = "Test String"
a.gsub(' ', '').underscore
=> "test_string"
编辑:正如@dft 指出的那样,这种方法不是Ruby 的一部分,而是Rails 的一部分。
查看Ruby Facets的蛇盒
处理以下情况,如下所示:
"SnakeCase".snakecase #=> "snake_case"
"Snake-Case".snakecase #=> "snake_case"
"Snake Case".snakecase #=> "snake_case"
"Snake - Case".snakecase #=> "snake_case"
来自:https ://github.com/rubyworks/facets/blob/master/lib/core/facets/string/snakecase.rb
class String
# Underscore a string such that camelcase, dashes and spaces are
# replaced by underscores. This is the reverse of {#camelcase},
# albeit not an exact inverse.
#
# "SnakeCase".snakecase #=> "snake_case"
# "Snake-Case".snakecase #=> "snake_case"
# "Snake Case".snakecase #=> "snake_case"
# "Snake - Case".snakecase #=> "snake_case"
#
# Note, this method no longer converts `::` to `/`, in that case
# use the {#pathize} method instead.
def snakecase
#gsub(/::/, '/').
gsub(/([A-Z]+)([A-Z][a-z])/,'\1_\2').
gsub(/([a-z\d])([A-Z])/,'\1_\2').
tr('-', '_').
gsub(/\s/, '_').
gsub(/__+/, '_').
downcase
end
#
alias_method :underscore, :snakecase
# TODO: Add *separators to #snakecase, like camelcase.
end
接收器转换为蛇盒:http ://rubydoc.info/gems/extlib/0.9.15/String#snake_case-instance_method
这是 DataMapper 和 Merb 的支持库。( http://rubygems.org/gems/extlib )
def snake_case
return downcase if match(/\A[A-Z]+\z/)
gsub(/([A-Z]+)([A-Z][a-z])/, '\1_\2').
gsub(/([a-z])([A-Z])/, '\1_\2').
downcase
end
"FooBar".snake_case #=> "foo_bar"
"HeadlineCNNNews".snake_case #=> "headline_cnn_news"
"CNN".snake_case #=> "cnn"
我想要这个:
class String
# \n returns the capture group of "n" index
def snakize
self.gsub(/::/, '/')
.gsub(/([a-z\d])([A-Z])/, "\1_\2")
.downcase
end
# or
def snakize
self.gsub(/::/, '/')
.gsub(/([a-z\d])([A-Z])/) do
"#{$1}_#{$2}"
end
.downcase
end
end
猴子补丁String
类。有些类以两个或多个大写字母开头。
ruby 核心本身不支持将字符串从(大写)驼峰大小写转换为(也称为帕斯卡大小写)到下划线(也称为蛇大小写)。
因此,您需要自己实现或使用现有的 gem。
有一个名为lucky_case的小型 ruby gem ,它允许您轻松地将字符串从 10 多种受支持的情况转换为另一种情况:
require 'lucky_case'
# convert to snake case string
LuckyCase.snake_case('CamelCaseString') # => 'camel_case_string'
# or the opposite way
LuckyCase.pascal_case('camel_case_string') # => 'CamelCaseString'
如果您愿意,您甚至可以修改 String 类:
require 'lucky_case/string'
'CamelCaseString'.snake_case # => 'camel_case_string'
'CamelCaseString'.snake_case! # => 'camel_case_string' and overwriting original
查看官方存储库以获取更多示例和文档:
我"CamelCaseString".underscore
在执行 rake 任务时遇到了麻烦。这帮助了我:
ActiveSupport::Inflector.underscore "CamelCaseString"
=> "camel_case_string"
当然,你需要 ActiveSupport