Logo
Книга для начинающих
ВходРегистрация
/
Программирование
/
Курс PHP
/

Поиск стартовой позиции

PHP: Поиск стартовой позиции

Часто в работе со строками нужно определить, является ли одна строка подстрокой — частью другой строки. В большинстве языков программирования есть встроенная функция, предназначенная именно для этой задачи.

В PHP такая функция появилась лишь в восьмой версии. До этого ее имитировали с помощью функции mb_strpos(). Эта функция ищет позицию первого вхождения одной строки в другую. Пока мы будем использовать именно mb_strpos():

<?php

if (mb_strpos('Валар Моргулис', 'Моргулис')) { // 6
    // ...
}

В примере выше функция вернет 6, что соответствует индексу буквы М:

<?php

if (mb_strpos('Валар Моргулис', 'Валар')) { // 0
    // ...
}

А в этом примере вернется 0, что соответствует первой букве строки. В этом коде скрыта ошибка, которую часто допускают новички. В PHP 0 рассматривается, как false — значит, условие не выполнится. Правильная проверка выглядит так:

<?php

if (mb_strpos('Валар Моргулис', 'Валар') !== false) {
    // ...
}

Функция mb_strpos() возвращает false, если подстрока не была найдена. Значит, можно воспользоваться строгим сравнением с false.

Задание

Допишите реализацию функции startsWith(), которая определяет, начинается ли строка с подстроки.

<?php

startsWith('Хекслет', 'ет'); // false
startsWith('Хекслет', 'Хек'); // true
Коммерческий опыт и Трудоустройство

Команда проекта находится в телеграм-сообществе. Там можно задать любой вопрос и повлиять на проект

Если вы зашли в тупик, то самое время поговорить с нашим асситентом Тота во вкладке "ИИ-помощник":

Тесты устроены таким образом, что они проверяют решение разными способами и на разных данных. Часто решение работает с одними входными данными, но не работает с другими. Чтобы разобраться с этим моментом, изучите вкладку «Тесты» и внимательно посмотрите на вывод ошибок, в котором есть подсказки.

Это нормально 🙆, в программировании одну задачу можно выполнить множеством способов. Если ваш код прошел проверку, то он соответствует условиям задачи. В редких случаях бывает, что решение подогнано под тесты, но это видно сразу.

Создавать обучающие материалы, понятные для всех без исключения, довольно сложно. Мы очень стараемся, но всегда есть что улучшать. Если вы встретили материал, который вам непонятен, опишите проблему в обратной связи нашего сообщества

Нашли ошибку? Есть что добавить? Пулреквесты приветствуются
/
Программирование
/
Курс PHP
/

Поиск стартовой позиции

PHP: Поиск стартовой позиции

Часто в работе со строками нужно определить, является ли одна строка подстрокой — частью другой строки. В большинстве языков программирования есть встроенная функция, предназначенная именно для этой задачи.

В PHP такая функция появилась лишь в восьмой версии. До этого ее имитировали с помощью функции mb_strpos(). Эта функция ищет позицию первого вхождения одной строки в другую. Пока мы будем использовать именно mb_strpos():

<?php

if (mb_strpos('Валар Моргулис', 'Моргулис')) { // 6
    // ...
}

В примере выше функция вернет 6, что соответствует индексу буквы М:

<?php

if (mb_strpos('Валар Моргулис', 'Валар')) { // 0
    // ...
}

А в этом примере вернется 0, что соответствует первой букве строки. В этом коде скрыта ошибка, которую часто допускают новички. В PHP 0 рассматривается, как false — значит, условие не выполнится. Правильная проверка выглядит так:

<?php

if (mb_strpos('Валар Моргулис', 'Валар') !== false) {
    // ...
}

Функция mb_strpos() возвращает false, если подстрока не была найдена. Значит, можно воспользоваться строгим сравнением с false.

Задание

Допишите реализацию функции startsWith(), которая определяет, начинается ли строка с подстроки.

<?php

startsWith('Хекслет', 'ет'); // false
startsWith('Хекслет', 'Хек'); // true
Коммерческий опыт и Трудоустройство

Команда проекта находится в телеграм-сообществе. Там можно задать любой вопрос и повлиять на проект

Если вы зашли в тупик, то самое время поговорить с нашим асситентом Тота во вкладке "ИИ-помощник":

Тесты устроены таким образом, что они проверяют решение разными способами и на разных данных. Часто решение работает с одними входными данными, но не работает с другими. Чтобы разобраться с этим моментом, изучите вкладку «Тесты» и внимательно посмотрите на вывод ошибок, в котором есть подсказки.

Это нормально 🙆, в программировании одну задачу можно выполнить множеством способов. Если ваш код прошел проверку, то он соответствует условиям задачи. В редких случаях бывает, что решение подогнано под тесты, но это видно сразу.

Создавать обучающие материалы, понятные для всех без исключения, довольно сложно. Мы очень стараемся, но всегда есть что улучшать. Если вы встретили материал, который вам непонятен, опишите проблему в обратной связи нашего сообщества

Нашли ошибку? Есть что добавить? Пулреквесты приветствуются
← ПредыдущийСледующий →
← ПредыдущийСледующий →
← ПредыдущийСледующий →

Ваше упражнение проверяется по этим тестам

<?php

namespace HexletBasics\DeepIntoStrings\StartWith;

use PHPUnit\Framework\TestCase;

class SolutionTest extends TestCase
{
    public function test()
    {
        require 'index.php';
        $this->assertTrue(startsWith('one', 'o'));
        $this->assertFalse(startsWith('one', 'ne'));
        $this->assertTrue(startsWith('one', 'on'));
        $this->assertTrue(startsWith('one', 'one'));
    }
}
← ПредыдущийСледующий →

Решение учителя откроется через:

20:00

waiting_clock
← ПредыдущийСледующий →