Відповіді:
Можна використовувати метод зрізу:
a = "foobar"
a.slice! "foo"
=> "foo"
a
=> "bar"
є не '!' версія також. Більш детальну інформацію можна знайти в документації щодо інших версій: http://www.ruby-doc.org/core/classes/String.html#method-i-slice-21
"foobar".tap{|s| s.slice!("foo")}.upcase
delete
не вийде, оскільки видаляє всіх персонажів, які ти передаєш :'hello world'.delete('hello') #=> ' wrd'
Як щодо str.gsub("subString", "")
перевірки документа Ruby
sub
було б більш доцільно, ніж gsub
оскільки ОП хоче лише видалити підрядку з початку рядка, а не все через рядок (дивіться його зразок коду). І використовувати регулярний вираз, як це, було б краще: str.sub(/^subString/, '')
- тому що це гарантує, що підряд, безумовно, буде видалений лише з початку.
subString
він не містить спеціальних символів для регулярних виразів.
/^subString/
є буквальним, тому ми можемо бути впевнені, що він не містить жодних метахарактерів. Якщо ви підставляючи деяку іншу рядок в регулярний вираз, ви можете зробити це: /#{Regexp.escape(str)}/
.
Regexp.escape()
, однак.
Якщо це кінець рядка, ви також можете використовувати chomp
:
"hello".chomp("llo") #=> "he"
chomp
в поєднанні з reverse
:"hello".reverse.chomp("he".reverse).reverse #=> "llo"
Якщо у вас є лише одна зустріч цільового рядка, ви можете використовувати:
str[target] = ''
або
str.sub(target, '')
Якщо у вас є кілька випадків цільового використання:
str.gsub(target, '')
Наприклад:
asdf = 'foo bar'
asdf['bar'] = ''
asdf #=> "foo "
asdf = 'foo bar'
asdf.sub('bar', '') #=> "foo "
asdf = asdf + asdf #=> "foo barfoo bar"
asdf.gsub('bar', '') #=> "foo foo "
Якщо вам потрібно зробити заміни на місці, використовуйте "!"
версії gsub!
та sub!
.
asdf['bar'] = ''
Якщо ви використовуєте Rails, також є remove
.
Наприклад, "Testmessage".remove("message")
урожайність "Test"
.
Попередження: цей метод видаляє всі події
slice
метод не повертає нарізану частину струни, вона повертає "ніж"
slice!
def gimme_the_slice(my_string, my_slice) my_string.slice!(my_slice) my_string
Якщо ваша підрядка знаходиться на початку в кінці рядка, то Ruby 2.5 ввів методи для цього:
Якщо ви використовуєте рейли або менше інструментів, у вас є String # remove і String # Remove! метод
def remove!(*patterns)
patterns.each do |pattern|
gsub! pattern, ""
end
self
end
джерело: http://api.rubyonrails.org/classes/String.html#method-i-remove
Якщо я правильно трактую, це питання, схоже, задає щось на зразок мінусу (-) операції між рядками, тобто протилежної вбудованій операції плюс (+) (конкатенація).
На відміну від попередніх відповідей, я намагаюся визначити таку операцію, яка повинна підкорятися властивості:
ЯКЩО c = a + b ТАГО c - a = b AND c - b = a
Для цього нам потрібно лише три вбудовані методи Ruby:
'abracadabra'.partition('abra').values_at(0,2).join == 'cadabra'
.
Я не поясню, як це працює, тому що його можна легко зрозуміти, використовуючи один метод за один раз.
Ось доказ поняття коду:
# minus_string.rb
class String
def -(str)
partition(str).values_at(0,2).join
end
end
# Add the following code and issue 'ruby minus_string.rb' in the console to test
require 'minitest/autorun'
class MinusString_Test < MiniTest::Test
A,B,C='abra','cadabra','abracadabra'
def test_C_eq_A_plus_B
assert C == A + B
end
def test_C_minus_A_eq_B
assert C - A == B
end
def test_C_minus_B_eq_A
assert C - B == A
end
end
Останнє слово поради, якщо ви використовуєте останню версію Ruby (> = 2.0): використовуйте доопрацювання замість String-стрижки мавпи, як у попередньому прикладі.
Це так просто, як:
module MinusString
refine String do
def -(str)
partition(str).values_at(0,2).join
end
end
end
і додайте using MinusString
перед блоками, де вам це потрібно.
ось що я зробив би
2.2.1 :015 > class String; def remove!(start_index, end_index) (end_index - start_index + 1).times{ self.slice! start_index }; self end; end;
2.2.1 :016 > "idliketodeleteHEREallthewaytoHEREplease".remove! 14, 32
=> "idliketodeleteplease"
2.2.1 :017 > ":)".remove! 1,1
=> ":"
2.2.1 :018 > "ohnoe!".remove! 2,4
=> "oh!"
Відформатовано у кілька рядків:
class String
def remove!(start_index, end_index)
(end_index - start_index + 1).times{ self.slice! start_index }
self
end
end
def replaceslug
slug = "" + name
@replacements = [
[ "," , ""],
[ "\\?" , ""],
[ " " , "-"],
[ "'" , "-"],
[ "Ç" , "c"],
[ "Ş" , "s"],
[ "İ" , "i"],
[ "I" , "i"],
[ "Ü" , "u"],
[ "Ö" , "o"],
[ "Ğ" , "g"],
[ "ç" , "c"],
[ "ş" , "s"],
[ "ı" , "i"],
[ "ü" , "u"],
[ "ö" , "o"],
[ "ğ" , "g"],
]
@replacements.each do |pair|
slug.gsub!(pair[0], pair[1])
end
self.slug = slug.downcase
end
Ö
.
[]
s для версії без чубства.