154 lines
		
	
	
		
			6.4 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			154 lines
		
	
	
		
			6.4 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
---
 | 
						||
title: Ruby String Methods
 | 
						||
localeTitle: Методы Ruby String
 | 
						||
---
 | 
						||
## Методы Ruby String
 | 
						||
 | 
						||
Ruby имеет много встроенных методов для работы со строками. Строки в Ruby по умолчанию изменяемы и могут быть изменены на месте или новая строка может быть возвращена из метода.
 | 
						||
 | 
						||
### Длина:
 | 
						||
 | 
						||
*   Свойство `.length` возвращает количество символов в строке, включая пробел. `ruby "Hello".length #=> 5 "Hello World!".length #=> 12`
 | 
						||
 | 
						||
### Empty:
 | 
						||
 | 
						||
*   `.empty?` метод возвращает `true` если длина строки равна нулю. `ruby "Hello".empty? #=> false "!".empty? #=> false " ".empty? #=> false "".empty? #=> true`
 | 
						||
 | 
						||
### Количество:
 | 
						||
 | 
						||
*   Метод `.count` подсчитывает, сколько раз в строке содержится определенный символ (символы).
 | 
						||
*   Этот метод чувствителен к регистру. `ruby "HELLO".count('L') #=> 2 "HELLO WORLD!".count('LO') #=> 1`
 | 
						||
 | 
						||
### Вставка:
 | 
						||
 | 
						||
*   Метод `.insert` вставляет строку в другую строку перед данным индексом. `ruby "Hello".insert(3, "hi5") #=> Helhi5lo # "hi5" is inserted into the string right before the second 'l' which is at index 3`
 | 
						||
 | 
						||
### Upcase:
 | 
						||
 | 
						||
*   Метод `.upcase` преобразует все буквы в строке в верхний регистр. `ruby "Hello".upcase #=> HELLO`
 | 
						||
 | 
						||
### Downcase:
 | 
						||
 | 
						||
*   Метод `.downcase` преобразует все буквы в строку в нижний регистр. `ruby "Hello".downcase #=> hello`
 | 
						||
 | 
						||
### Swapcase
 | 
						||
 | 
						||
*   Метод `.swapcase` преобразует `.swapcase` в строке в нижний регистр и строчные буквы в верхний регистр. `ruby "hELLO wORLD".swapcase #=> Hello World`
 | 
						||
 | 
						||
### прописной:
 | 
						||
 | 
						||
*   Метод `.capitalize` делает первую букву в строке в верхнем регистре, а остальную часть строки строчной. `ruby "HELLO".capitalize #=> Hello "HELLO, HOW ARE YOU?".capitalize #=> Hello, how are you?`
 | 
						||
 | 
						||
_Обратите внимание, что первая буква только заглавная, если она находится в начале строки._ `ruby "-HELLO".capitalize #=> -hello "1HELLO".capitalize #=> 1hello`
 | 
						||
 | 
						||
### Задний ход:
 | 
						||
 | 
						||
*   `.reverse` метод отменяет порядок символов в строке. `ruby "Hello World!".reverse #=> "!dlroW olleH"`
 | 
						||
 | 
						||
### Трещина:
 | 
						||
 | 
						||
*   `.split` берет строки и _разбивает_ их на массив, а затем возвращает массив.
 | 
						||
    
 | 
						||
    ```ruby
 | 
						||
    "Hello, how are you?".split #=> ["Hello,", "how", "are", "you?"] 
 | 
						||
    
 | 
						||
    ```
 | 
						||
    
 | 
						||
*   Метод по умолчанию разбивает строку на основе пробелов, если не указан другой разделитель (см. Второй пример). `ruby "Hello".split('-') #=> ["H", "e", "l", "l", "o"]`
 | 
						||
    
 | 
						||
 | 
						||
### Чоп:
 | 
						||
 | 
						||
*   Метод `.chop` удаляет последний символ строки.
 | 
						||
    
 | 
						||
*   Возвращается новая строка, если вы не используете `.chop!` метод, который мутирует исходную строку.
 | 
						||
    
 | 
						||
    ```ruby
 | 
						||
    "Name".chop #=> Nam 
 | 
						||
    
 | 
						||
    ```
 | 
						||
    
 | 
						||
    ```ruby
 | 
						||
    name = "Batman" 
 | 
						||
     name.chop 
 | 
						||
     name == "Batma" #=> false 
 | 
						||
    
 | 
						||
    ```
 | 
						||
    
 | 
						||
    ```ruby
 | 
						||
    name = "Batman" 
 | 
						||
     name.chop! 
 | 
						||
     name == "Batma" #=> true 
 | 
						||
    
 | 
						||
    ```
 | 
						||
    
 | 
						||
 | 
						||
### Газа:
 | 
						||
 | 
						||
*   Метод `.strip` удаляет ведущие и конечные пробелы в строках, включая табуляции, новые строки и возврат каретки ( `\t` , `\n` , `\r` ). `ruby " Hello ".strip #=> Hello`
 | 
						||
 | 
						||
### Chomp:
 | 
						||
 | 
						||
*   Метод `.chomp` удаляет последний символ в строке, только если это возврат каретки или `.chomp` строка ( `\r` , `\n` ).
 | 
						||
*   Этот метод обычно используется с командой `gets` для удаления возвратов из пользовательского ввода. ``ruby "hello\r".chomp #=> hello "hello\t".chomp #=> hello\t # because tabs and other whitespace remain intact when using `chomp` ``
 | 
						||
 | 
						||
### К Integer:
 | 
						||
 | 
						||
*   Метод `.to_i` преобразует строку в целое число. `ruby "15".to_i #=> 15 # integer`
 | 
						||
 | 
						||
### GSUB:
 | 
						||
 | 
						||
*   `gsub` заменяет каждую ссылку первого параметра для второго параметра на строку.
 | 
						||
 | 
						||
```ruby
 | 
						||
"ruby is cool".gsub("cool", "very cool") #=> "ruby is very cool" 
 | 
						||
```
 | 
						||
 | 
						||
*   `gsub` также принимает шаблоны (например, _regexp_ ) в качестве первого параметра, позволяя такие вещи, как:
 | 
						||
 | 
						||
```ruby
 | 
						||
"ruby is cool".gsub(/[aeiou]/, "*") #=> "r*by *sc**l" 
 | 
						||
```
 | 
						||
 | 
						||
### конкатенация:
 | 
						||
 | 
						||
*   Ruby реализует некоторые методы, чтобы объединить две строки вместе:
 | 
						||
    
 | 
						||
*   Метод `+` :
 | 
						||
    
 | 
						||
    ```ruby
 | 
						||
    "15" + "15" #=> "1515" # string 
 | 
						||
    
 | 
						||
    ```
 | 
						||
    
 | 
						||
*   Метод `<<` :
 | 
						||
    
 | 
						||
    ```ruby
 | 
						||
    "15" << "15" #=> "1515" # string 
 | 
						||
    
 | 
						||
    ```
 | 
						||
    
 | 
						||
*   Метод `concat` : `ruby "15".concat "15" #=> "1515" # string`
 | 
						||
    
 | 
						||
 | 
						||
### Индекс:
 | 
						||
 | 
						||
*   Метод `index` возвращает позицию индекса первого совпадения соответствия подстроки или шаблона регулярного выражения в строке.
 | 
						||
    
 | 
						||
*   Если совпадения не найдено, возвращается `nil` .
 | 
						||
    
 | 
						||
*   Второй необязательный параметр указывает, какая позиция индекса в строке начала поиск совпадения.
 | 
						||
    
 | 
						||
    ```ruby
 | 
						||
    "information".index('o') #=> 3 
 | 
						||
     "information".index('mat') #=> 5 
 | 
						||
     "information".index(/[abc]/) #=> 6 
 | 
						||
     "information".index('o', 5) #=> 9 
 | 
						||
     "information".index('z') #=> nil 
 | 
						||
    
 | 
						||
    ```
 | 
						||
    
 | 
						||
 | 
						||
### Очистить:
 | 
						||
 | 
						||
*   Удаляет содержимое строки. `ruby a = "abcde" a.clear #=> ""` |