मैं एक नाम को सांप के मामले से ऊंट मामले में बदलने की कोशिश कर रहा हूं। क्या कोई अंतर्निहित तरीके हैं?
जैसे: "app_user"को"AppUser"
(मेरे पास एक स्ट्रिंग है जिसे "app_user"मैं मॉडल में बदलना चाहता हूं AppUser)।
मैं एक नाम को सांप के मामले से ऊंट मामले में बदलने की कोशिश कर रहा हूं। क्या कोई अंतर्निहित तरीके हैं?
जैसे: "app_user"को"AppUser"
(मेरे पास एक स्ट्रिंग है जिसे "app_user"मैं मॉडल में बदलना चाहता हूं AppUser)।
जवाबों:
यदि आप रेल का उपयोग कर रहे हैं, तो स्ट्रिंग # कैमलाइज़ करें जो आप खोज रहे हैं।
"active_record".camelize # => "ActiveRecord"
"active_record".camelize(:lower) # => "activeRecord"
यदि आप एक वास्तविक वर्ग प्राप्त करना चाहते हैं, तो आपको उसके शीर्ष पर स्ट्रिंग # स्थिरांक का उपयोग करना चाहिए ।
"app_user".camelize.constantize
ruby-on-rails, इसलिए, मुझे लगता है, यह कोई समस्या नहीं है। लेकिन उल्लेख करने के लिए धन्यवाद।
#classifyइसके बजाय उपयोग करें । "some_namespace/module/class_name".classify => "SomeNamespace::Module::ClassName"
require "active_support/core_ext/string"पर्याप्त है, बशर्ते रेल पहले से ही स्थापित हो।
इसके बारे में क्या खयाल है?
"hello_world".split('_').collect(&:capitalize).join #=> "HelloWorld"
यहाँ टिप्पणियों में मिला: रूबी स्ट्रिंग वर्गीकृत करें
वेन कॉनराड की टिप्पणी देखें
यदि आप रेल का उपयोग करते हैं, तो उपयोग करें classify। यह किनारे के मामलों को अच्छी तरह से संभालता है।
"app_user".classify # => AppUser
"user_links".classify # => UserLink
ध्यान दें:
यह उत्तर प्रश्न में दिए गए विवरण के लिए विशिष्ट है (यह प्रश्न शीर्षक के लिए विशिष्ट नहीं है)। यदि कोई ऊंट-मामले में एक स्ट्रिंग को बदलने की कोशिश कर रहा है, तो उन्हें सर्जियो के उत्तर का उपयोग करना चाहिए । प्रश्नकर्ता राज्यों वह परिवर्तित करने के लिए चाहता है कि app_userकरने के लिए AppUser(नहीं App_user), इसलिए इस जवाब ..
classifyएक स्ट्रिंग लौटाता है, आपको constantizeइसे वास्तविक वर्ग में बदलने के लिए बाद में कॉल करना होगा।
classifyयह है कि बहुवचन तार विलक्षण हो जाएंगे ... 'age_in_years'.classifyबन जाता हैAgeInYear
4.2.11
स्रोत: http://rubydoc.info/gems/extlib/0.9.15/String#camel_case-instance_method
सीखने के उद्देश्य के लिए:
class String
def camel_case
return self if self !~ /_/ && self =~ /[A-Z]+.*/
split('_').map{|e| e.capitalize}.join
end
end
"foo_bar".camel_case #=> "FooBar"
और लोअरकेस संस्करण के लिए:
class String
def camel_case_lower
self.split('_').inject([]){ |buffer,e| buffer.push(buffer.empty? ? e : e.capitalize) }.join
end
end
"foo_bar".camel_case_lower #=> "fooBar"
self.split('_').inject([]){ |buffer,e| buffer + [buffer.empty? ? e : e.capitalize] }.join
मैंने हर संभावना को ध्यान में रखते हुए इसे शुद्ध रूबी कोड के साथ किया, यहाँ वे हैं:
पूंजीकरण और gsub
'app_user'.capitalize.gsub(/_(\w)/){$1.upcase}विभाजन और &शॉर्टहैंड का उपयोग करके नक्शा (उपयोगकर्ता 3869936 के जवाब के लिए धन्यवाद)
'app_user'.split('_').map(&:capitalize).joinविभाजन और नक्शा (श्री ब्लैक के जवाब के लिए धन्यवाद)
'app_user'.split('_').map{|e| e.capitalize}.joinऔर यहाँ इन सभी के लिए बेंचमार्क है, हम देख सकते हैं कि इसके लिए gsub काफी खराब है। मैंने 126 080 शब्दों का इस्तेमाल किया।
user system total real
capitalize and gsub : 0.360000 0.000000 0.360000 ( 0.357472)
split and map, with &: 0.190000 0.000000 0.190000 ( 0.189493)
split and map : 0.170000 0.000000 0.170000 ( 0.171859)
मैं यहाँ आपके प्रश्न के विलोम की तलाश में, ऊँट के मामले से साँप के मामले में जा रहा था। उस के लिए अंडरस्कोर का उपयोग करें (डीमेलिज़ाइज़ नहीं):
AppUser.name.underscore # => "app_user"
या, यदि आपके पास पहले से ही एक ऊंट केस स्ट्रिंग है:
"AppUser".underscore # => "app_user"
या, यदि आप तालिका का नाम प्राप्त करना चाहते हैं, जो संभवत: इसीलिए आप सांप का मामला चाहते हैं:
AppUser.name.tableize # => "app_users"
AppUser.table_name? यदि यह app_users नहीं है, लेकिन कहीं और परिभाषित किया गया है, तो आप सही तालिका का नाम भी सुनिश्चित करेंगे।
मुझे यहाँ और उत्तर जोड़ने में थोड़ी असहजता महसूस हो रही है। सबसे पठनीय और न्यूनतम शुद्ध रूबी दृष्टिकोण के लिए जाने का फैसला किया, @ ulysse-bn से अच्छा बेंचमार्क की उपेक्षा। हालांकि :classमोड @ user3869936 की एक प्रति है, लेकिन जो :methodमोड मैं यहां किसी अन्य उत्तर में नहीं देखता हूं।
def snake_to_camel_case(str, mode: :class)
case mode
when :class
str.split('_').map(&:capitalize).join
when :method
str.split('_').inject { |m, p| m + p.capitalize }
else
raise "unknown mode #{mode.inspect}"
end
end
परिणाम है:
[28] pry(main)> snake_to_camel_case("asd_dsa_fds", mode: :class)
=> "AsdDsaFds"
[29] pry(main)> snake_to_camel_case("asd_dsa_fds", mode: :method)
=> "asdDsaFds"
PascalCaseका एक सबसेट है CamelCase। यह भी मुझे पता है - कि ऊंट का मामला दोनों पर लागू होता है। लेकिन मैंने कभी जांच नहीं की। PascalCase का उल्लेख करने के लिए धन्यवाद। en.wikipedia.org/wiki/Camel_case
:methodसंस्करण ने downcaseपहले किया तो इसका उपयोग दोनों पर किया जा सकता है lower_snake_caseऔर UPPER_SNAKE_CASE।
यहां सूचीबद्ध अन्य विधियों में से अधिकांश रेल विशिष्ट हैं। यदि आप शुद्ध रूबी के साथ ऐसा करना चाहते हैं, तो सबसे संक्षिप्त तरीका है जिसके साथ मैं आया हूं (सुझाए गए सुधार के लिए @ ulysse-bn को धन्यवाद)
x="this_should_be_camel_case"
x.gsub(/(?:_|^)(\w)/){$1.upcase}
#=> "ThisShouldBeCamelCase"
x.gsub(/(?:_|^)(\w)/){$1.upcase}
gsubसमाधान पर वापस आ गए हैं, ऐसा लगता है कि mapसमाधान की तुलना में धीमी है ।
शुद्ध रूबी में आप रेलगाड़ियों को रेल के समान कोड का उपयोग करके बढ़ा सकते हैं .camelize
class String
def camelize(uppercase_first_letter = true)
string = self
if uppercase_first_letter
string = string.sub(/^[a-z\d]*/) { |match| match.capitalize }
else
string = string.sub(/^(?:(?=\b|[A-Z_])|\w)/) { |match| match.downcase }
end
string.gsub(/(?:_|(\/))([a-z\d]*)/) { "#{$1}#{$2.capitalize}" }.gsub("/", "::")
end
end