Question

Y at-il fonction prêt qui convertit cas de chameau cordes en underscore chaîne séparée?

Je veux quelque chose comme ceci:

"CamelCaseString".to_underscore      

pour revenir "camel_case_string".

...

Était-ce utile?

La solution

Rails' ActiveSupport ajoute à souligner la chaîne en utilisant les éléments suivants:

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

Ensuite, vous pouvez faire des choses amusantes:

"CamelCase".underscore
=> "camel_case"

Autres conseils

Vous pouvez utiliser

"CamelCasedName".tableize.singularize

Ou

"CamelCasedName".underscore

Les deux options façons donneront "camel_cased_name". Vous pouvez vérifier plus de détails, il .

mise en œuvre Ruby One-liner:

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"

Il existe une méthode intégrée Rails appelée « underscore » que vous pouvez utiliser à cette fin

"CamelCaseString".underscore #=> "camel_case_string" 

La méthode 'underscore' peut généralement être considérée comme inverse de 'camelize'

Voilà comment Rails-t-il :

   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

récepteur converti en cas de serpent: http://rubydoc.info/ pierres précieuses / extlib / 0.9.15 / String # snake_case-instance_method

Ceci est la bibliothèque de support pour DataMapper et 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"

Consultez snake case Ruby Facettes

Les cas suivants sont traités, comme on le voit ci-dessous:

"SnakeCase".snakecase         #=> "snake_case"
"Snake-Case".snakecase        #=> "snake_case"
"Snake Case".snakecase        #=> "snake_case"
"Snake  -  Case".snakecase    #=> "snake_case"

De: https: // GitHub. com / rubyworks / facettes / blob / maître / lib / core / facettes / 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

courte ligne pour les cas Camel lorsque vous avez des espaces également inclus (si vous n'avez fonctionnera pas correctement un mot inbetween avec un petit départ lettre):

a = "Test String"
a.gsub(' ', '').underscore

  => "test_string"

Je voudrais ceci:

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

patch singe de classe String. Il y a la classe qui commencent par deux ou plusieurs lettres en majuscules.

Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top