Domanda

Esiste funzione pronta che converte caso cammello stringhe in sottolineatura stringa separata?

Voglio qualcosa di simile:

"CamelCaseString".to_underscore      

per tornare "camel_case_string".

...

È stato utile?

Soluzione

Rails' ActiveSupport aggiunge sottolineare alla stringa utilizzando il seguente:

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

Poi si può fare cose divertenti:

"CamelCase".underscore
=> "camel_case"

Altri suggerimenti

È possibile utilizzare

"CamelCasedName".tableize.singularize

O semplicemente

"CamelCasedName".underscore

Entrambe le opzioni modi produrranno "camel_cased_name". È possibile verificare i dettagli si qui .

Un-liner implementazione di 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

Quindi "SomeCamelCase".to_underscore # =>"some_camel_case"

C'è un metodo integrato Rails chiamato 'sottolineatura' che è possibile utilizzare per questo scopo

"CamelCaseString".underscore #=> "camel_case_string" 

Il metodo 'sottolineatura' in genere può essere considerato come inverso della 'camelize'

Ecco come Rails lo fa :

   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

Ricevente convertito in caso di serpente: http://rubydoc.info/ gemme / EXTLIB / 0.9.15 / String # snake_case-instance_method

Questa è la libreria di supporto per DataMapper e 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"

Scopri snake case rubino sfaccettature

I seguenti casi sono trattati, come si vede qui sotto:

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

Da: https: // GitHub. com / rubyworks / sfaccettature / blob / master / lib / core / sfaccettature / 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

Breve uno di linea per i casi Camel quando si hanno spazi inclusi anche (non funziona correttamente se si dispone di una parola inbetween con piccoli partenza-lettera):

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

  => "test_string"

Vorrei che questo:

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

toppa Scimmia di classe String. Ci sono di classe che iniziano con due o più lettere maiuscole.

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top