Gibt es eine Ready-Funktion, die Camel Case-Strings in durch Unterstriche getrennte Strings umwandelt?
Ich möchte so etwas:
"CamelCaseString".to_underscore
um "camel_case_string" zurückzugeben.
...
Rails 'ActiveSupport fügt dem String den folgenden Unterstrich hinzu:
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
Dann kannst du lustige Sachen machen:
"CamelCase".underscore
=> "camel_case"
Sie können verwenden
"CamelCasedName".tableize.singularize
Oder nur
"CamelCasedName".underscore
Beide Möglichkeiten ergeben "camel_cased_name"
. Sie können weitere Details überprüfen hier .
Einzeilige Ruby Implementierung:
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
So "SomeCamelCase".to_underscore # =>"some_camel_case"
Es gibt eine Rails eingebaute Methode namens 'Underscore', die Sie für diesen Zweck verwenden können
"CamelCaseString".underscore #=> "camel_case_string"
Die "Unterstrich" -Methode kann normalerweise als Inverse von "camelize" angesehen werden.
Hier ist, wie Rails macht es :
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
Empfänger konvertiert nach Snake Case: http://rubydoc.info/gems/extlib/0.9.15/String#snake_case-instance_method
Dies ist die Support-Bibliothek für DataMapper und 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"
Check out snakecase von Ruby Facets
Die folgenden Fälle werden wie folgt behandelt:
"SnakeCase".snakecase #=> "snake_case"
"Snake-Case".snakecase #=> "snake_case"
"Snake Case".snakecase #=> "snake_case"
"Snake - Case".snakecase #=> "snake_case"
Von: 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
Kurzer Einzeiler für Camel Cases, wenn auch Leerzeichen enthalten sind (funktioniert nicht richtig, wenn sich ein Wort mit kleinem Anfangsbuchstaben dazwischen befindet):
a = "Test String"
a.gsub(' ', '').underscore
=> "test_string"
Das würde mir gefallen:
class String
# \n returns the capture group of "n" index
def snikize
self.gsub(/::/, '/')
.gsub(/([a-z\d])([A-Z])/, "\1_\2")
.downcase
end
# or
def snikize
self.gsub(/::/, '/')
.gsub(/([a-z\d])([A-Z])/) do
"#{$1}_#{$2}"
end
.downcase
end
end
Affen-Patch der Klasse String
. Es gibt Klassen, die mit zwei oder mehr Großbuchstaben beginnen.