Логические формулы в excel

Операторы И и ИЛИ

Синтаксис оператора И выглядит следующим образом:

=И(лог_значение1; лог_значение2; …), возможное количество используемых аргументов – от 1 до 255.

Оператор И используется в качестве элемента-связки для нескольких условий логического выражения

Важно, чтобы все аргументы оператора имели значение ИСТИНА (если в выражении их несколько), в противном случае вся логическая цепочка будет возвращать значение ЛОЖЬ

Синтаксис оператора ИЛИ:

=ИЛИ(лог_значение1; лог_значение2; …), возможное количество используемых аргументов – от 1 до 255.

В отличие от И, функция ИЛИ будет возвращать значение ИСТИНА даже в случае, когда хотя бы один из используемых аргументов ему соответствует, а все остальные – ложные.

Как получить значение по модулю числа без использования функции ABS

Пример 3. Реализовать алгоритм определения значения модуля числа (абсолютную величину), то есть альтернативный вариант для функции ABS.

Таблица данных:

Для решения используем формулу массива:

=ЕСЛИ(НЕ(A3:A100, функция НЕ будет возвращать ЛОЖЬ.

Если единственным аргументом функции НЕ является текстовая строка, функция вернет код ошибки #ЗНАЧ!. В вычислительной технике используется специальный логический тип данных (в программировании имеет название «булев» тип или Boolean в честь известного математика Джорджа Буля). Этот тип данных оперирует всего двумя значениями: 1 и 0 (ИСТИНА, ЛОЖЬ). В Excel истинному логическому значению также соответствует число 1, а ложному логическому значению – также числовое значение 0 (нуль). Функции ИСТИНА() и ЛОЖЬ() могут быть введены в любую ячейку или использоваться в формуле и будут интерпретированы в качестве логических значений соответственно. Обе рассмотренные выше функции необходимы для обеспечения совместимости с другими программными продуктами, предназначенными для работы с таблицами. Функция НЕ позволяет расширить возможности функций, предназначенных для выполнения логической проверки. Например, при использовании данной функции в качестве аргумента лог_выражение функции ЕСЛИ, можно обеспечить проверку сразу нескольких условий.

Среди множества различных выражений, которые применяются при работе с Microsoft Excel, следует выделить логические функции. Их применяют для указания выполнения различных условий в формулах. При этом, если сами условия могут быть довольно разнообразными, то результат логических функций может принимать всего два значения: условие выполнено (ИСТИНА) и условие не выполнено (ЛОЖЬ). Давайте подробнее разберемся, что представляют собой логические функции в Экселе.

Общее определение и задачи

«ЕСЛИ» является стандартной функцией программы Microsoft Excel. В ее задачи входит проверка выполнения конкретного условия. Когда условие выполнено (истина), то в ячейку, где использована данная функция, возвращается одно значение, а если не выполнено (ложь) – другое.

Синтаксис этой функции выглядит следующим образом: «ЕСЛИ(логическое выражение; ; )» .

Пример использования «ЕСЛИ»

Теперь давайте рассмотрим конкретные примеры, где используется формула с оператором «ЕСЛИ».

  1. Имеем таблицу заработной платы. Всем женщинам положена премия к 8 марту в 1000 рублей. В таблице есть колонка, где указан пол сотрудников. Таким образом, нам нужно вычислить женщин из предоставленного списка и в соответствующих строках колонки «Премия к 8 марта» вписать по «1000». В то же время, если пол не будет соответствовать женскому, значение таких строк должно соответствовать «0». Функция примет такой вид: «ЕСЛИ(B6=»жен.»; «1000»; «0»)» . То есть когда результатом проверки будет «истина» (если окажется, что строку данных занимает женщина с параметром «жен.»), то выполнится первое условие — «1000», а если «ложь» (любое другое значение, кроме «жен.»), то соответственно, последнее — «0».
  2. Вписываем это выражение в самую верхнюю ячейку, где должен выводиться результат. Перед выражением ставим знак «=».

Так мы получили таблицу со столбцом, заполненным при помощи функции «ЕСЛИ».

Пример функции с несколькими условиями

В функцию «ЕСЛИ» можно также вводить несколько условий. В этой ситуации применяется вложение одного оператора «ЕСЛИ» в другой. При выполнении условия в ячейке отображается заданный результат, если же условие не выполнено, то выводимый результат зависит уже от второго оператора.

  1. Для примера возьмем все ту же таблицу с выплатами премии к 8 марта. Но на этот раз, согласно условиям, размер премии зависит от категории работника. Женщины, имеющие статус основного персонала, получают бонус по 1000 рублей, а вспомогательный персонал получает только 500 рублей. Естественно, что мужчинам этот вид выплат вообще не положен независимо от категории.
  2. Первым условием является то, что если сотрудник — мужчина, то величина получаемой премии равна нулю. Если же данное значение ложно, и сотрудник не мужчина (т.е. женщина), то начинается проверка второго условия. Если женщина относится к основному персоналу, в ячейку будет выводиться значение «1000», а в обратном случае – «500». В виде формулы это будет выглядеть следующим образом: «=ЕСЛИ(B6=»муж.»;»0″; ЕСЛИ(C6=»Основной персонал»; «1000»;»500″))» .
  3. Вставляем это выражение в самую верхнюю ячейку столбца «Премия к 8 марта».

Как и в прошлый раз, «протягиваем» формулу вниз.

Пример с выполнением двух условий одновременно

В функции «ЕСЛИ» можно также использовать оператор «И», который позволяет считать истинной только выполнение двух или нескольких условий одновременно.

  1. Например, в нашей ситуации премия к 8 марта в размере 1000 рублей выдается только женщинам, которые являются основным персоналом, а мужчины и представительницы женского пола, числящиеся вспомогательным персоналом, не получают ничего. Таким образом, чтобы значение в ячейках колонки «Премия к 8 марта» было 1000, нужно соблюдение двух условий: пол – женский, категория персонала – основной персонал. Во всех остальных случаях значение в этих ячейках будет рано нулю. Это записывается следующей формулой: «=ЕСЛИ(И(B6=»жен.»; C6=»Основной персонал»); «1000»; «0»)» . Вставляем ее в ячейку.

Копируем значение формулы на ячейки, расположенные ниже, аналогично продемонстрированным выше способам.

Пример использования оператора «ИЛИ»

В функции «ЕСЛИ» также может использоваться оператор «ИЛИ». Он подразумевает, что значение является истинным, если выполнено хотя бы одно из нескольких условий.

  1. Итак, предположим, что премия к 8 марта в 1000 рублей положена только женщинам, которые входят в число основного персонала. В этом случае, если работник — мужчина или относится к вспомогательному персоналу, то величина его премии будет равна нулю, а иначе – 1000 рублей. В виде формулы это выглядит так: «=ЕСЛИ(ИЛИ(B6=»муж.»; C6=»Вспомогательный персонал»); «0»; «1000»)» . Записываем ее в соответствующую ячейку таблицы.

«Протягиваем» результаты вниз.

Как видим, функция «ЕСЛИ» может оказаться для пользователя хорошим помощником при работе с данными в Microsoft Excel. Она позволяет отобразить результаты, соответствующие определенным условиям.

Как извлечь число из конца текстовой строки.

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

Важное замечание! В приведенных ниже формулах извлечение выполняется с помощью функций ПРАВСИМВ и ЛЕВСИМВ, которые относятся к категории текстовых функций. Эти функции всегда возвращают текст. В нашем случае результатом будет числовая подстрока, которая с точки зрения Excel также является текстом, а не числом. Если вам нужно, чтобы результат был числом (которое можно использовать в дальнейших вычислениях), оберните соответствующую формулу в  или выполните с ней простейшую математическую операцию (например, двойное отрицание). Чтобы извлечь число из строки «текстовое число», первое, что вам нужно знать, — это с какой позиции начать операцию. Итак, давайте определим положение первой цифры с помощью этой общего выражения:

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

О логике вычислений мы поговорим чуть позже. На данный момент просто замените слово «ячейка» ссылкой на позицию, содержащую исходный текст (в нашем случае A2), и запишите получившееся выражение в любую пустую клетку той же строки, скажем, в B2:

Хотя формула содержит константу массива, это обычное выражение, которое вводится обычным способом: нажатием клавиши Enter.

Как только позиция первой цифры определена, можно использовать функцию ПРАВСИМВ для извлечения числа. Чтобы узнать, сколько символов нужно извлечь, вы вычитаете позицию первой цифры из общей длины строки и добавляете единицу к результату, потому что первая цифра также должна быть включена:

Где A2 — исходная ячейка, а B2 — позиция первой цифры.

На следующем скриншоте показаны результаты:

Чтобы исключить вспомогательный столбец, содержащий позицию первой цифры, вы можете встроить формулу МИН непосредственно в функцию ПРАВСИМВ следующим образом:

Чтобы формула возвращала именно число, а не числовую строку, вложите ее в функцию ЗНАЧЕН:

Или просто примените двойное отрицание, использовав два знака «минус»:

Другой способ извлечь число из конца строки — использовать вот такое выражение:

Используя исходный текст в A2, вы записываете приведенную ниже формулу в B2 или любую другую пустую ячейку в той же строке, а затем копируете её вниз по столбцу:

Примечание. Эти формулы предназначены для случая, когда числа находятся только в конце текстовой строки. Если некоторые цифры также находятся в середине или в начале, то ничего не будет работать. 

Этих недостатков не имеет третья формула, которая извлекает только последнее число в тексте, игнорируя все предыдущие:

На скриншоте ниже вы видите результат ее работы.

Как видите, цифры в начале или в середине текста игнорируются

Также обратите внимание, что результатом, как и в предыдущих формулах, является число, записанное в виде текста. Как превратить его в нормальное число, мы уже рассмотрели выше в этой статье

Примечание. Если вы используете Excel 2019 или более ранние версии, нужно использовать формулу массива, нажав при вводе комбинацию . Если у вас Office365, вводите как обычно, через .

Практический пример использования логических функций

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

В качестве исходных данных – таблица со сведениями о работниках, в которой указан их пол и возраст.

Нам необходимо произвести расчет премии. Ключевые условия, от которых зависит размер премии:

  • величина обычной премии, которую получат все сотрудники без исключения – 3 000 руб.;
  • сотрудницам женского пола положена повышенная премия – 7 000 руб.;
  • молодым сотрудникам (младше 1984 г. рождения) положена повышенная премия – 7 000 руб.;

Выполним необходимые расчеты, используя логические функции.

Встаем в первую ячейку столбца, в которой хотим посчитать размеры премий и щелкаем кнопку “Вставить функцию” (слева от сроки формул).

В открывшемся Мастере функций выбираем категорию “Логические”, затем в предложенном перечне операторов кликаем по строке “ЕСЛИ” и жмем OK.

Теперь нам нужно задать аргументы функции. Так как у нас не одно, а два условия получения повышенной премии, причем нужно, чтобы выполнялось хотя бы одно из них, чтобы задать логическое выражение, воспользуемся функцией ИЛИ. Находясь в поле для ввода значения аргумента “Лог_выражение” кликаем в основной рабочей области книги на небольшую стрелку вниз, расположенную в левой верхней части окна программы, где обычно отображается адрес ячейки. В открывшемся списке функций выбираем оператор ИЛИ, если он представлен в перечне (или можно кликнуть на пункт “Другие функции” и выбрать его в новом окне Мастера функций, как мы изначально сделали для выбора оператора ЕСЛИ).

Мы переключимся в окно аргументов функци ИЛИ

Здесь задаем наши условия получения премии в 7000 руб.:год рождения позже 1984 года;
пол – женский;

Теперь обращаем внимание на строку формул. Кликаем в ней на название первоначального оператора ЕСЛИ, чтобы переключиться в аргументы этой функции.

Заполняем аргументы функции и щелкаем OK:в значении “Истина” пишем цифру 7000;
в значении “Ложь” указываем цифру 3000;

Результат работы логических операторов отобразится в первой ячейке столбца, которую мы выбрали

Как мы можем видеть, окончательный вид формулы выглядит следующим образом:. Кстати, вместо использования Мастера функций можно было вручную составить и прописать данную формулу в требуемой ячейке.

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

Все готово. Благодаря логическим операторам мы получили заполненные данные для столбца с премиями.

Главные операторы

Существует несколько операторов логических функций. Посреди главных следует выделить такие:

  • ИСТИНА;
  • ЛОЖЬ;
  • ЕСЛИ;
  • ЕСЛИОШИБКА;
  • ИЛИ;
  • И;
  • НЕ;
  • ЕОШИБКА;
  • ЕПУСТО.

Есть и наименее всераспространенные логические функции.

У всякого из вышеуказанных операторов, не считая первых 2-ух, имеются аргументы. Аргументами могут выступать, как определенные числа либо текст, так и ссылки, указывающие адресок ячеек с данными.

Функции ИСТИНА и ЛОЖЬ

Оператор ИСТИНА воспринимает лишь определенное данное значение. У данной функции отсутствуют аргументы, и, обычно, она фактически постоянно является составной частью наиболее сложных выражений.

Оператор ЛОЖЬ, напротив, воспринимает хоть какое значение, которое не является правдой. Буквально так же эта функция не имеет аргументов и заходит в наиболее сложные выражения.

Функции И и ИЛИ

Функция И является связывающим звеном меж несколькими критериями. Лишь при выполнении всех критерий, которые связывает данная функция, она возвращает значение ИСТИНА. Если хотя бы один аргумент докладывает значение ЛОЖЬ, то и оператор И в целом возвращает это значение. Вид данной функции: =И(лог_значение1;лог_значение2;…) . Функция может включать в себя от 1 до 255 аргументов.

Функция ИЛИ, напротив, возвращает значение ИСТИНА даже в том случае, если лишь один из аргументов отвечает условиям, а все другие неверные. Её шаблон имеет последующий вид: =И(лог_значение1;лог_значение2;…) . Как и предшествующая функция, оператор ИЛИ может включать в себя от 1 до 255 критерий.

Функция НЕ

В отличие от 2-ух прошлых операторов, функция НЕ имеет всего только один аргумент. Она меняет значение выражения с ИСТИНА на ЛОЖЬ в пространстве обозначенного аргумента. Общий синтаксис формулы смотрится последующим образом: =НЕ(лог_значение) .

Функции ЕСЛИ и ЕСЛИОШИБКА

Для наиболее сложных конструкций употребляется функция ЕСЛИ. Данный оператор показывает, какое конкретно значение является ИСТИНА, а какое ЛОЖЬ. Его общий шаблон смотрится последующим образом: =ЕСЛИ(логическое_выражение;значение_если_истина;значение_если-ложь) . Таковым образом, если условие соблюдается, то в ячейку, содержащую данную функцию, заполняют заблаговременно обозначенные данные. Если условие не соблюдается, то ячейка заполняется иными данными, обозначенными в 3-ем по счету аргументе функции.

Оператор ЕСЛИОШИБКА, в случае если аргумент является правдой, возвращает в ячейку его собственное значение. Но, если аргумент неверный, тогда в ячейку ворачивается то значение, которое показывает юзер. Синтаксис данной функции, содержащей всего два аргумента, смотрится последующем образом: =ЕСЛИОШИБКА(значение;значение_если_ошибка) .

Функции ЕОШИБКА и ЕПУСТО

Функция ЕОШИБКА инспектирует, не содержит ли определенная ячейка либо спектр ячеек неверные значения. Под неверными значениями понимаются последующие:

  • #Н/Д;
  • #ЗНАЧ;
  • #ЧИСЛО!;
  • #ДЕЛ/0!;
  • #ССЫЛКА!;
  • #ИМЯ?;
  • #ПУСТО!

Зависимо от того неверный аргумент либо нет, оператор докладывает значение ИСТИНА либо ЛОЖЬ. Синтаксис данной функции последующий: = ЕОШИБКА(значение) . В роли аргумента выступает только ссылка на ячейку либо на массив ячеек.

Оператор ЕПУСТО делает проверку ячейки на то, пустая ли она либо содержит значения. Если ячейка пустая, функция докладывает значение ИСТИНА, если ячейка содержит данные – ЛОЖЬ. Синтаксис этого оператора имеет таковой вид: =ЕПУСТО(значение) . Так же, как и в прошлом случае, аргументом выступает ссылка на ячейку либо массив.

Функция ИЛИ() в MS EXCEL

​ ячейку. То есть​ В3 и ввели​Формула предписывает программе Excel​ простых логических условий.​Следствием этого является возможность​Функция И​ указываться.​во всей ее​

Синтаксис функции

​ ячейки таблицы, можно​

​ и другими логическими​​ еще в нескольких​ равна или меньше​Усложненные функции ЕСЛИ: как​​Если у простой функции​​ продажи нет, поэтому​ вернуть 1, в​Назовем новую графу «№​​ при автозаполнении или​​ =.​ порядок действий с​ Все шесть возможных​ альтернативной записи формулы​Функция ИЛИ​

​лог_выражение2…лог_выражение127​ красе и примерах,​​ увидеть, что 2​ функциями Excel, можно​ случаях. Первая ситуация​ 5, но больше​

​ работать с вложенными​ ЕСЛИ есть только​ вернуть 0)​ противном случае вернуть 2)​ п/п». Вводим в​ копировании константа остается​Щелкнули по ячейке В2​ числами, значениями в​ операторов сравнения приведены​

Совместное использование с функцией ЕСЛИ()

​ =ИЛИ(A1>100;A2>100) в виде​Функция ВПР​(необязательно)​ а также разобрали​ человека из 5​ решать достаточно сложные​ обозначается редактором, как​ 3. Должен быть​​ формулами и избежать​ два результата (ИСТИНА​

​Рекомендации по использованию констант​=ЕСЛИ(C2=1;»Да»;»Нет»)​ первую ячейку «1»,​​ неизменной (или постоянной).​​ – Excel «обозначил»​ ячейке или группе​ в таблице ниже:​ =(A1>100)+(A2>100)​Полные сведения о​

Сравнение с функцией И()

​Условие, принимающее значение ИСТИНА​ простой пример с​ не прошли переаттестацию.​ задачи. В этом​ «ДЕЛ/0» и встречается​ отображен комментарий: «проходит».​ ошибок​ и ЛОЖЬ), то​В последнем примере текстовое​В этом примере ячейка​ во вторую –​Чтобы указать Excel на​

Эквивалентность функции ИЛИ() операции сложения +

​ ее (имя ячейки​ ячеек. Без формул​Операторы сравнения позволяют задавать​Значение второй формулы​ формулах в Excel​ или ЛОЖЬ.​ использованием сразу нескольких​

​Функции​ уроке мы попробуем​ достаточно часто. Как​ В противном случае​​Обучающие видео: усложненные функции​ у вложенных функций​ значение «Да» и​ D2 содержит формулу:​ «2». Выделяем первые​ абсолютную ссылку, пользователю​ появилось в формуле,​ электронные таблицы не​ условия, которые возвращают​

​ будет =0 (ЛОЖЬ),​Рекомендации, позволяющие избежать​значение_если_истина2…значение_если_истина127​ функций​ЕСЛИ​ разобрать ее действие​ правило, она возникает​ – «нет». Итак,​​ ЕСЛИ​​ ЕСЛИ может быть​​ ставка налога с​

Проверка множества однотипных условий

​ЕСЛИ(C2 = 1, то​ две ячейки –​ необходимо поставить знак​​ вокруг ячейки образовался​​ нужны в принципе.​ логические значения ИСТИНА​​ только если оба​​ появления неработающих формул​(необязательно)​ЕСЛИ​можно вкладывать друг​ на простых примерах,​ в тех случаях,​ проходят лишь те​​Подсчет значений на основе​​ от 3 до​ продажи (0,0825) введены​ вернуть текст «Да»,​ «цепляем» левой кнопкой​ доллара ($). Проще​​ «мелькающий» прямоугольник).​​Конструкция формулы включает в​ или ЛОЖЬ. Примеры​​ аргумента ложны, т.е.​​Исправление распространенных ошибок​​Результат, возвращаемый, если условие​​в одной формуле.​

​ в друга, если​ а также научимся​ когда подлежит копированию​​ учащиеся, которые получили​

​ одного условия с​ 64 результатов.​ прямо в формулу.​ в противном случае​​ мыши маркер автозаполнения​

​ всего это сделать​Ввели знак *, значение​ себя: константы, операторы,​ использования логических условий​ равны 0. Только​ в формулах с​лог_выражениеN​

excel2.ru>

Как извлечь подстроку после последнего вхождения разделителя

При работе со сложными текстовыми выражениями, которые содержат несколько вхождений одного и того же разделителя, вам часто может потребоваться получить текст справа от последнего появления разделителя. Чтобы упростить понимание, взгляните на следующие исходные данные и желаемый результат:рис4

Как вы можете видеть на скриншоте выше, столбец A содержит список ошибок. Ваша цель — получить описание ошибки, которое идет после последнего двоеточия. Дополнительная сложность заключается в том, что исходные значения могут содержать разное количество разделителей, например, A3 содержит 3 двоеточия, а A5 — только одно.

Ключом к поиску решения является определение позиции последнего разделителя (последнее вхождение двоеточия в этом примере). Для этого вам нужно будет выполнить несколько несложных операций:

  1. Подсчитайте количество разделителей в исходной строке. Это несложно:
    • Вычисляете общую ее длину с помощью ДЛСТР(A2).
    • Определяем длину без разделителей, используя формулу ПОДСТАВИТЬ, которая заменяет все вхождения двоеточия ничем: ДЛСТР(ПОДСТАВИТЬ(A2; «:»; «»))
    • Наконец, вы вычитаете длину исходной строки без разделителей из общей длины:  ДЛСТР(A2)-ДЛСТР(ПОДСТАВИТЬ(A2;»:»;»»))

Чтобы убедиться, что формула работает правильно, вы можете ввести ее в отдельную ячейку, и результатом будет 2, то есть количество двоеточий в ячейке A2.

  1. Замените последний разделитель на какой-нибудь уникальный символ. Чтобы извлечь текст, который идет после последнего разделителя, нам нужно каким-то образом «пометить» это последнее вхождение разделителя. Для этого давайте заменим последнее вхождение двоеточия символом, который нигде не встречается в исходных значениях, например, знаком доллара ($).

Если вы знакомы с синтаксисом функции ПОДСТАВИТЬ, вы можете помнить, что у нее есть 4-й необязательный аргумент (номер вхождения), который позволяет заменять только конкретное появление указанного символа. И поскольку мы уже вычислили количество разделителей, просто впишите рассмотренное выше выражение в четвертый аргумент функции ПОДСТАВИТЬ:

Если вы поместите эту формулу в отдельную ячейку, она вернет:          ERROR: 432 $ Connection timed out

  1. Определяем позицию последнего разделителя. В зависимости от того, на какой символ вы заменили последний разделитель, используйте ПОИСК (без учета регистра) или НАЙТИ (с учетом регистра), чтобы определить позицию этого символа. Мы заменили последнее двоеточие на знак $, поэтому используем следующую формулу, чтобы узнать его местоположение:

ПОИСК(«$»; ПОДСТАВИТЬ(A2;»:»;»$»;ДЛСТР(A2)-ДЛСТР(ПОДСТАВИТЬ(A2;»:»;»»)))))

В этом примере формула возвращает 10, что является позицией $ в измененном тексте.

  1. Получаем подстроку справа от последнего разделителя. Теперь, когда вы знаете позицию последнего разделителя, все, что вам нужно сделать, это вычесть это число из общей длины строки и использовать ПРАВСИМВ, чтобы вернуть это количество символов из конца исходного текста:

ПРАВСИМВ(A2;ДЛСТР(A2)-ПОИСК(«$»; ПОДСТАВИТЬ(A2;»:»;»$»;ДЛСТР(A2)-ДЛСТР(ПОДСТАВИТЬ(A2;»:»;»»)))))

Если вы работаете с большим набором данных, где разные ячейки могут содержать различные разделители, вы можете заключить приведенную выше формулу в функцию ЕСЛИОШИБКА, чтобы предотвратить возможные сообщения об ошибках:

Как показано на скриншоте ниже, формула работает отлично:

Замечание. В случае, если ячейка не содержит ни одного вхождения указанного разделителя, будет возвращена исходная строка целиком.

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *

Adblock
detector