Excel для Microsoft 365 Excel для Microsoft 365 для Mac Excel для Интернета Excel 2021 Excel 2021 для Mac Excel 2019 Excel 2019 для Mac Excel 2016 Excel 2016 для Mac Excel 2013 Excel 2010 Excel 2007 Еще…Меньше
Хотя в Excel предлагается большое число встроенных функций, в нем может не быть той функции, которая нужна для ваших вычислений. К сожалению, разработчики Excel не могли предугадать все потребности пользователей. Однако в Excel можно создавать собственные функции, и ниже вы найдете все нужные для этого инструкции.
Пользовательские функции (как и макросы) записываются на языке программирования Visual Basic для приложений (VBA). Они отличаются от макросов двумя вещами. Во-первых, в них используются процедуры Function, а не Sub. Это значит, что они начинаются с оператора Function, а не Sub, и заканчиваются оператором End Function, а не End Sub. Во-вторых, они выполняют различные вычисления, а не действия. Некоторые операторы (например, предназначенные для выбора и форматирования диапазонов) исключаются из пользовательских функций. Из этой статьи вы узнаете, как создавать и применять пользовательские функции. Для создания функций и макросов используется редактор Visual Basic (VBE), который открывается в отдельном окне.
Предположим, что ваша компания предоставляет скидку в размере 10 % клиентам, заказавшим более 100 единиц товара. Ниже мы объясним, как создать функцию для расчета такой скидки.
В примере ниже показана форма заказа, в которой перечислены товары, их количество и цена, скидка (если она предоставляется) и итоговая стоимость.
Чтобы создать пользовательскую функцию DISCOUNT в этой книге, сделайте следующее:
-
Нажмите клавиши ALT+F11 (или FN+ALT+F11 на Mac), чтобы открыть редактор Visual Basic, а затем щелкните Insert (Вставка) > Module (Модуль). В правой части редактора Visual Basic появится окно нового модуля.
-
Скопируйте указанный ниже код и вставьте его в новый модуль.
Function DISCOUNT(quantity, price) If quantity >=100 Then DISCOUNT = quantity * price * 0.1 Else DISCOUNT = 0 End If DISCOUNT = Application.Round(Discount, 2) End Function
Примечание: Чтобы код было более удобно читать, можно добавлять отступы строк с помощью клавиши TAB. Отступы необязательны и не влияют на выполнение кода. Если добавить отступ, редактор Visual Basic автоматически вставит его и для следующей строки. Чтобы сдвинуть строку на один знак табуляции влево, нажмите SHIFT+TAB.
Теперь вы готовы использовать новую функцию DISCOUNT. Закройте редактор Visual Basic, выделите ячейку G7 и введите следующий код:
=DISCOUNT(D7;E7)
Excel вычислит 10%-ю скидку для 200 единиц по цене 47,50 ₽ и вернет 950,00 ₽.
В первой строке кода VBA функция DISCOUNT(quantity, price) указывает, что функции DISCOUNT требуется два аргумента: quantity (количество) и price (цена). При вызове функции в ячейке листа необходимо указать эти два аргумента. В формуле =DISCOUNT(D7;E7) аргумент quantity имеет значение D7, а аргумент price — значение E7. Если скопировать формулу в ячейки G8:G13, вы получите указанные ниже результаты.
Рассмотрим, как Excel обрабатывает эту функцию. При нажатии клавиши ВВОД Excel ищет имя DISCOUNT в текущей книге и определяет, что это пользовательская функция в модуле VBA. Имена аргументов, заключенные в скобки (quantity и price), представляют собой заполнители для значений, на основе которых вычисляется скидка.
Оператор If в следующем блоке кода проверяет аргумент quantity и сравнивает количество проданных товаров со значением 100:
If quantity >= 100 Then DISCOUNT = quantity * price * 0.1 Else DISCOUNT = 0 End If
Если количество проданных товаров не меньше 100, VBA выполняет следующую инструкцию, которая перемножает значения quantity и price, а затем умножает результат на 0,1:
Discount = quantity * price * 0.1
Результат хранится в виде переменной Discount. Оператор VBA, который хранит значение в переменной, называется оператором назначения, так как он вычисляет выражение справа от знака равенства и назначает результат имени переменной слева от него. Так как переменная Discount называется так же, как и процедура функции, значение, хранящееся в переменной, возвращается в формулу листа, из которой была вызвана функция DISCOUNT.
Если значение quantity меньше 100, VBA выполняет следующий оператор:
Discount = 0
Наконец, следующий оператор округляет значение, назначенное переменной Discount, до двух дробных разрядов:
Discount = Application.Round(Discount, 2)
В VBA нет функции округления, но она есть в Excel. Чтобы использовать округление в этом операторе, необходимо указать VBA, что метод (функцию) Round следует искать в объекте Application (Excel). Для этого добавьте слово Application перед словом Round. Используйте этот синтаксис каждый раз, когда нужно получить доступ к функции Excel из модуля VBA.
Пользовательские функции должны начинаться с оператора Function и заканчиваться оператором End Function. Помимо названия функции, оператор Function обычно включает один или несколько аргументов. Однако вы можете создать функцию без аргументов. В Excel доступно несколько встроенных функций (например, СЛЧИС и ТДАТА), в которых нет аргументов.
После оператора Function указывается один или несколько операторов VBA, которые проверят соответствия условиям и выполняют вычисления с использованием аргументов, переданных функции. Наконец, в процедуру функции следует включить оператор, назначающий значение переменной с тем же именем, что у функции. Это значение возвращается в формулу, которая вызывает функцию.
Количество ключевых слов VBA, которые можно использовать в пользовательских функциях, меньше числа, используемого в макросах. Настраиваемые функции не могут выполнять другие задачи, кроме возврата значения в формулу на этом или в выражение, используемом в другом макросе или функции VBA. Например, пользовательские функции не могут изменять размер окна, редактировать формулу в ячейке, а также изменять шрифт, цвет или узор текста в ячейке. Если в процедуру функции включить такой код действия, функция возвращает #VALUE! ошибку «#ВЫЧИС!».
Единственное действие, которое может выполнять процедура функции (кроме вычислений), — это отображение диалогового окна. Чтобы получить значение от пользователя, выполняющего функцию, можно использовать в ней оператор InputBox. Кроме того, с помощью оператора MsgBox можно выводить сведения для пользователей. Вы также можете использовать настраиваемые диалоговые окна (UserForms), но эта тема выходит за рамки данной статьи.
Даже простые макросы и пользовательские функции может быть сложно понять. Чтобы сделать эту задачу проще, добавьте комментарии с пояснениями. Для этого нужно ввести перед текстом апостроф. Например, ниже показана функция DISCOUNT с комментариями. Благодаря подобным комментариями и вам, и другим будет впоследствии проще работать с кодом VBA. Так, код будет легче понять, если потребуется внести в него изменения.
Апостроф указывает приложению Excel на то, что следует игнорировать всю строку справа от него, поэтому вы можете добавлять комментарии в отдельных строках или в правой части строк, содержащих код VBA. Советуем начинать длинный блок кода с комментария, в котором объясняется его назначение, а затем использовать встроенные комментарии для документирования отдельных операторов.
Кроме того, рекомендуется присваивать макросам и пользовательским функциям описательные имена. Например, присвойте макросу название MonthLabels вместо Labels, чтобы более точно указать его назначение. Описательные имена макросов и пользовательских функций особенно полезны, если существует множество процедур с похожим назначением.
То, как документировать макрос и пользовательские функции, имеет личный выбор. Важно принятия определенного способа документации и его согласованного использования.
Для использования настраиваемой функции должна быть открыта книга, содержащая модуль, в котором она была создана. Если книга не открыта, вы получите #NAME? при попытке использования функции. Если вы ссылались на функцию в другой книге, ее имя должно предшествовать названию книги, в которой она находится. Например, при создании функции DISCOUNT в книге Personal.xlsb и вызове ее из другой книги необходимо ввести =personal.xlsb!discount(),а не просто =discount().
Чтобы вставить пользовательскую функцию быстрее (и избежать ошибок), ее можно выбрать в диалоговом окне «Вставка функции». Пользовательские функции доступны в категории «Определенные пользователем»:
Чтобы пользовательские функции всегда были доступны, можно хранить их в отдельной книге, а затем сохранять в качестве надстройки. Затем надстройку можно сделать доступной при запуске Excel. Вот как это сделать:
-
Создав нужные функции, выберите Файл > Сохранить как.
В Excel 2007 нажмите кнопку Microsoft Office, а затем щелкните Сохранить как.
-
В диалоговом окне Сохранить как откройте раскрывающийся список Тип файла и выберите значение Надстройка Excel. Сохраните книгу с запоминающимся именем, таким как MyFunctions, в папке AddIns. Она будет автоматически предложена в диалоговом окне Сохранить как, поэтому вам потребуется только принять расположение, используемое по умолчанию.
-
Сохранив книгу, выберите Файл > Параметры Excel.
В Excel 2007 нажмите кнопку Microsoft Office и щелкните Параметры Excel.
-
В диалоговом окне Параметры Excel выберите категорию Надстройки.
-
В раскрывающемся списке Управление выберите Надстройки Excel. Затем нажмите кнопку Перейти.
-
В диалоговом окне Надстройки установите флажок рядом с именем книги, как показано ниже.
-
Создав нужные функции, выберите Файл > Сохранить как.
-
В диалоговом окне Сохранить как откройте раскрывающийся список Тип файла и выберите значение Надстройка Excel. Сохраните книгу с запоминающимся именем, таким как MyFunctions.
-
Сохранив книгу, выберите Сервис > Надстройки Excel.
-
В диалоговом окне Надстройки нажмите кнопку «Обзор», найдите свою надстройку, нажмите кнопку Открыть, а затем установите флажок рядом с надстройкой в поле Доступные надстройки.
После этого пользовательские функции будут доступны при каждом запуске Excel. Если вы хотите добавить его в библиотеку функций, вернимся в Visual Basic редактора. Если вы заглянуть в Visual Basic редактора Project проводника под заголовком VBAProject, вы увидите модуль с именем файла надстройки. У надстройки будет расширение XLAM.
Дважды щелкните модуль в Project Explorer, чтобы вывести код функций. Чтобы добавить новую функцию, установите точку вставки после оператора End Function, который завершает последнюю функцию в окне кода, и начните ввод. Вы можете создать любое количество функций, и они будут всегда доступны в категории «Определенные пользователем» диалогового окна Вставка функции.
Эта статья основана на главе книги Microsoft Office Excel 2007 Inside Out, написанной Марком Доджем (Mark Dodge) и Крейгом Стинсоном (Craig Stinson). В нее были добавлены сведения, относящиеся к более поздним версиям Excel.
Дополнительные сведения
Вы всегда можете задать вопрос специалисту Excel Tech Community или попросить помощи в сообществе Answers community.
Нужна дополнительная помощь?
Skip to content
В решении многих задач обычные функции Excel не всегда могут помочь. Если существующих функций недостаточно, Excel позволяет добавить новые настраиваемые пользовательские функции (UDF). Они делают вашу работу легче.
Мы расскажем, как можно их создать, какие они бывают и как использовать их, чтобы ваша работа стала проще. Узнайте, как записать и использовать пользовательские функции, которые многие называют макросами..
- Что такое пользовательская функция
- Для чего ее используют?
- Как создать пользовательскую функцию в VBA?
- Как использовать пользовательскую функцию в формуле?
- Какие бывают типы пользовательских функций
Что такое пользовательская функция в Excel?
На момент написания этой статьи Excel предлагает вам более 450 различных функций. С их помощью вы можете выполнять множество различных операций. Но разработчики Microsoft Excel не могли предвидеть все задачи, которые нам нужно решать. Думаю, что многие из вас встречались с этими проблемами:
- не все данные могут быть обработаны стандартными функциями (например, даты до 1900 года).
- формулы могут быть весьма длинными и сложными. Их невозможно запомнить, трудно понять и сложно изменить для решения новой задачи.
- Не все задачи могут быть решены при помощи стандартных функций Excel (в частности, нельзя извлечь интернет-адрес из гиперссылки).
- Невозможно автоматизировать часто повторяющиеся стандартные операции (импорт данных из бухгалтерской программы на лист Excel, форматирование дат и чисел, удаление лишних колонок).
Как можно решить эти проблемы?
- Для очень сложных формул многие пользователи создают архив рабочих книг с примерами. Они копируют оттуда нужную формулу и применяют ее в своей таблице.
- Создание макросов VBA.
- Создание пользовательских функций при помощи редактора VBA.
Хотя первые два варианта кажутся вам знакомыми, третий может вызвать некоторую путаницу. Итак, давайте подробнее рассмотрим настраиваемые функции в Excel и решим, стоит ли их использовать.
Пользовательская функция – это настраиваемый код, который принимает исходные данные, производит вычисление и возвращает желаемый результат.
Исходными данными могут быть числа, текст, даты, логические значения, массивы. Результатом вычислений может быть значение любого типа, с которым работает Excel, или массив таких значений.
Другими словами, пользовательская функция – это своего рода модернизация стандартных функций Excel. Вы можете использовать ее, когда возможностей обычных функций недостаточно. Основное ее назначение – дополнить и расширить возможности Excel, выполнить действия, которые невозможны со стандартными возможностями.
Существует несколько способов создания собственных функций:
- при помощи Visual Basic for Applications (VBA). Этот способ описывается в данной статье.
- с использованием замечательной функции LAMBDA, которая появилась в Office365.
- при помощи Office Scripts. На момент написания этой статьи они доступны в Excel Online в подписке на Office365.
Посмотрите на скриншот ниже, чтобы увидеть разницу между двумя способами извлечения чисел — с использованием формулы и пользовательской функции ExtractNumber().
Даже если вы сохранили эту огромную формулу в своем архиве, вам нужно ее найти, скопировать и вставить, а затем аккуратно поправить все ссылки на ячейки. Согласитесь, это потребует затрат времени, да и ошибки не исключены.
А на ввод функции вы потратите всего несколько секунд.
Для чего можно использовать?
Вы можете использовать настраиваемую функцию одним из следующих способов:
- В формуле, где она может брать исходные данные из вашего рабочего листа и возвращать рассчитанное значение или массив значений.
- Как часть кода макроса VBA или другой пользовательской функции.
- В формулах условного форматирования.
- Для хранения констант и списков данных.
Для чего нельзя использовать пользовательские функции:
- Любого изменения другой ячейки, кроме той, в которую она записана,
- Изменения имени рабочего листа,
- Копирования листов рабочей книги,
- Поиска и замены значений,
- Изменения форматирования ячейки, шрифта, фона, границ, включения и отключения линий сетки,
- Вызова и выполнения макроса VBA, если его выполнение нарушит перечисленные выше ограничения. Если вы используете строку кода, который не может быть выполнен, вы можете получить ошибку RUNTIME ERROR либо просто одну из стандартных ошибок (например, #ЗНАЧЕН!).
Как создать пользовательскую функцию в VBA?
Прежде всего, необходимо открыть редактор Visual Basic (сокращенно — VBE). Обратите внимание, что он открывается в новом окне. Окно Excel при этом не закрывается.
Самый простой способ открыть VBE — использовать комбинацию клавиш. Это быстро и всегда доступно. Нет необходимости настраивать ленту или панель инструментов быстрого доступа. Нажмите Alt + F11
на клавиатуре, чтобы открыть VBE. И снова нажмите Alt + F11
, когда редактор открыт, чтобы вернуться назад в окно Excel.
После открытия VBE вам нужно добавить новый модуль. В него вы будете записывать ваш код. Щелкните правой кнопкой мыши на панели проекта VBA слева и выберите «Insert», затем появившемся справа окне — “Module”.
Справа появится пустое окно модуля, в котором вы и будете создавать свою функцию.
Прежде чем начать, напомним правила, по которым создается функция.
- Пользовательская функция всегда начинается с оператора Function и заканчивается инструкцией End Function.
- После оператора Function указывают имя функции. Это название, которое вы создаете и присваиваете, чтобы вы могли идентифицировать и использовать ее позже. Оно не должно содержать пробелов. Если вы хотите разделять слова, используйте подчеркивания. Например, Count_Words.
- Кроме того, это имя также не может совпадать с именами стандартных функций Excel. Если вы сделаете это, то всегда будет выполняться стандартная функция.
- Имя пользовательской функции не может совпадать с адресами ячеек на листе. Например, имя ABC1234 невозможно присвоить.
- Настоятельно рекомендуется давать описательные имена. Тогда вы можете легко выбрать нужное из длинного списка функций. Например, имя CountWords позволяет легко понять, что она делает, и при необходимости применить ее для подсчета слов.
- Далее в скобках обычно перечисляют аргументы. Это те данные, с которыми она будет работать. Может быть один или несколько аргументов. Если у вас несколько аргументов, их нужно перечислить через запятую.
- После этого обычно объявляются переменные, которые использует пользовательская функция. Указывается тип этих переменных – число, дата, текст, массив.
- Если операторы, которые вы используете внутри вашей функции, не используют никакие аргументы (например, NOW (СЕЙЧАС), TODAY (СЕГОДНЯ) или RAND (СЛЧИС)), то вы можете создать функцию без аргументов. Также аргументы не нужны, если вы используете функцию для хранения констант (например, числа Пи).
- Затем записывают несколько операторов VBA, которые выполняют вычисления с использованием переданных аргументов.
- В конце вы должны вставить оператор, который присваивает итоговое значение переменной с тем же именем, что и имя функции. Это значение возвращается в формулу, из которой была вызвана пользовательская функция.
- Записанный вами код может включать комментарии. Они помогут вам не забыть назначение функции и отдельных ее операторов. Если вы в будущем захотите внести какие-то изменения, комментарии будут вам очень полезны. Комментарий всегда начинается с апострофа (‘). Апостроф указывает Excel игнорировать всё, что записано после него, и до конца строки.
Теперь давайте попробуем создать вашу первую собственную формулу. Для начала мы создаем код, который будет подсчитывать количество слов в диапазоне ячеек.
Для этого в окно модуля вставим этот код:
Function CountWords(NumRange As Range) As Long
Dim rCell As Range, lCount As Long
For Each rCell In NumRange
lCount = lCount + _
Len(WorksheetFunction.Trim(rCell)) - Len(Replace(WorksheetFunction.Trim(rCell), " ", "")) + 1
Next rCell
CountWords = lCount
End Function
Я думаю, здесь могут потребоваться некоторые пояснения.
Код функции всегда начинается с пользовательской процедуры Function. В процедуре Function мы делаем описание новой функции.
В начале мы должны записать ее имя: CountWords.
Затем в скобках указываем, какие исходные данные она будет использовать. NumRange As Range означает, что аргументом будет диапазон значений. Сюда нужно передать только один аргумент — диапазон ячеек, в котором будет происходить подсчёт.
As Long указывает, что результат выполнения функции CountWords будет целым числом.
Во второй строке кода мы объявляем переменные.
Оператор Dim объявляет переменные:
rCell — переменная диапазона ячеек, в котором мы будем подсчитывать слова.
lCount — переменная целое число, в которой будет записано число слов.
Цикл For Each… Next предназначен для выполнения вычислений по отношению к каждому элементу из группы элементов (нашего диапазона ячеек). Этот оператор цикла применяется, когда неизвестно количество элементов в группе. Начинаем с первого элемента, затем берем следующий и так повторяем до самого последнего значения. Цикл повторяется столько раз, сколько ячеек имеется во входном диапазоне.
Внутри этого цикла с значением каждой ячейки выполняется операция, которая вычисляет количество слов:
Len(WorksheetFunction.Trim(rCell)) — Len(Replace(WorksheetFunction.Trim(rCell), » «, «»)) + 1
Как видите, это обычная формула Excel, которая использует стандартные средства работы с текстом: LEN, TRIM и REPLACE. Это английские названия знакомых нам русскоязычных ДЛСТР, СЖПРОБЕЛЫ и ЗАМЕНИТЬ. Вместо адреса ячейки рабочего листа используем переменную диапазона rCell. То есть, для каждой ячейки диапазона мы последовательно считаем количество слов в ней.
Подсчитанные числа суммируются и сохраняются в переменной lCount:
lCount = lCount + Len(WorksheetFunction.Trim(rCell)) — Len(Replace(WorksheetFunction.Trim(rCell), » «, «»)) + 1
Когда цикл будет завершен, значение переменной присваивается функции.
CountWords = lCount
Функция возвращает в ячейку рабочего листа значение этой переменной, то есть общее количество слов.
Именно эта строка кода гарантирует, что функция вернет значение lCount обратно в ячейку, из которой она была вызвана.
Закрываем наш код с помощью «End Function».
Как видите, не очень сложно.
Сохраните вашу работу. Для этого просто нажмите кнопку “Save” на ленте VB редактора.
После этого вы можете закрыть окно редактора. Для этого можно использовать комбинацию клавиш Alt+Q
. Или просто вернитесь на лист Excel, нажав Alt+F11
.
Вы можете сравнить работу с пользовательской функцией CountWords и подсчет количества слов в диапазоне при помощи формул.
Как использовать пользовательскую функцию в формуле?
Когда вы создали пользовательскую, она становится доступной так же, как и другие стандартные функции Excel. Сейчас мы узнаем, как создавать с ее помощью собственные формулы.
Чтобы использовать ее, у вас есть две возможности.
Первый способ. Нажмите кнопку fx
в строке формул. Среди появившихся категорий вы увидите новую группу — Определённые пользователем. И внутри этой категории вы можете увидеть нашу новую пользовательскую функцию CountWords.
Второй способ. Вы можете просто записать эту функцию в ячейку так же, как вы это делаете обычно. Когда вы начинаете вводить имя, Excel покажет вам имя пользовательской в списке соответствующих функций. В приведенном ниже примере, когда я ввел = cou , Excel показал мне список подходящих функций, среди которых вы видите и CountWords.
Можно посчитать этой же функцией и количество слов в диапазоне. Запишите в ячейку С3:
=CountWords(A2:A5)
Нажмите Enter
.
Мы только что указали функцию и установили диапазон, и вот результат подсчета: 14 слов.
Для сравнения в C1 я записал формулу массива, при помощи которой мы также можем подсчитать количество слов в диапазоне.
Как видите, результаты одинаковы. Только использовать CountWords() гораздо проще и быстрее.
Различные типы пользовательских функций с использованием VBA.
Теперь мы познакомимся с разными типами пользовательских функций в зависимости от используемых ими аргументов и результатов, которые они возвращают.
Без аргументов.
В Excel есть несколько стандартных функций, которые не требуют аргументов (например, СЛЧИС , СЕГОДНЯ , СЕЧАС). Например, СЛЧИС возвращает случайное число от 0 до 1. СЕГОДНЯ вернет текущую дату. Вам не нужно передавать им какие-либо значения.
Вы можете создать такую функцию и в VBA.
Ниже приведен код, который запишет в ячейку имя вашего рабочего листа.
Function SheetName() as String
Application.Volatile
SheetName = Application.Caller.Worksheet.Name
End Function
Или же можно использовать такой код:
SheetName = ActiveSheet.Name
Обратите внимание, что в скобках после имени нет ни одного аргумента. Здесь не требуется никаких аргументов, так как результат, который нужно вернуть, не зависит от каких-либо значений в вашем рабочем файле.
Приведенный выше код определяет результат функции как тип данных String (поскольку желаемый результат — это имя файла, которое является текстом). Если вы не укажете тип данных, то Excel будет определять его самостоятельно.
С одним аргументом.
Создадим простую функцию, которая работает с одним аргументом, то есть с одной ячейкой. Наша задача – извлечь из текстовой строки последнее слово.
Function ReturnLastWord(The_Text As String)
Dim stLastWord As String
'Extracts the LAST word from a text string
stLastWord = StrReverse(The_Text)
stLastWord = Left(stLastWord, InStr(1, stLastWord, " ", vbTextCompare))
ReturnLastWord = StrReverse(Trim(stLastWord))
End Function
Аргумент The_Text — это значение выбранной ячейки. Указываем, что это должно быть текстовое значение (As String).
Оператор StrReverse возвращает текст с обратным порядком следования знаков. Далее InStr определяет позицию первого пробела. При помощи Left получаем все знаки заканчивая первым пробелом. Затем удаляем пробелы при помощи Trim. Вновь меняем порядок следования символов при помощи StrReverse. Получаем последнее слово из текста.
Поскольку эта функция принимает значение ячейки, нам не нужно использовать здесь Application.Volatile. Как только аргумент изменится, функция автоматически обновится.
Использование массива в качестве аргумента.
Многие функции Excel используют массивы значений как аргументы. Вспомните функции СУММ, СУММЕСЛИ, СУММПРОИЗВ.
Мы уже рассмотрели эту ситуацию выше, когда учились создавать пользовательскую функцию для подсчета количества слов в диапазоне ячеек.
Приведённый ниже код создает функцию, которая суммирует все чётные числа в указанном диапазоне ячеек.
Function SumEven(NumRange as Range)
Dim RngCell As Range
For Each RngCell In NumRange
If IsNumeric(RngCell.Value) Then
If RngCell.Value Mod 2 = 0 Then
Result = Result + RngCell.Value
End If
End If
Next RngCell
SumEven = Result
End Function
Аргумент NumRange указан как Range. Это означает, что функция будет использовать массив исходных данных. Необходимо отметить, что можно использовать также тип переменной Variant. Это выглядит как
Function SumEven(NumRange as Variant)
Тип Variant обеспечивает «безразмерный» контейнер для хранения данных. Такая переменная может хранить данные любого из допустимых в VBA типов, включая числовые значения, текст, даты и массивы. Более того, одна и та же такая переменная в одной и той же программе в разные моменты может хранить данные различных типов. Excel самостоятельно будет определять, какие данные передаются в функцию.
В коде есть цикл For Each … Next, который берет каждую ячейку и проверяет, есть ли в ней число. Если это не так, то ничего не происходит, и он переходит к следующей ячейке. Если найдено число, он проверяет, четное оно или нет (с помощью функции MOD).
Все чётные числа суммируются в переменной Result.
Когда цикл будет закончен, значение Result присваивается переменной SumEven и передаётся функции.
С несколькими аргументами.
Большинство функций Excel имеет несколько аргументов. Не являются исключением и пользовательские функции. Поэтому так важно уметь создавать собственные функции с несколькими аргументами.
В приведенном ниже коде создается функция, которая выбирает максимальное число в заданном интервале.
Она имеет 3 аргумента: диапазон значений, нижняя граница числового интервала, верхняя граница интервала.
Function GetMaxBetween(rngCells As Range, MinNum, MaxNum)
Dim NumRange As Range
Dim vMax
Dim arrNums()
Dim i As Integer
ReDim arrNums(rngCells.Count)
For Each NumRange In rngCells
vMax = NumRange
Select Case vMax
Case MinNum + 0.01 To MaxNum - 0.01
arrNums(i) = vMax
i = i + 1
Case Else
GetMaxBetween = 0
End Select
Next NumRange
GetMaxBetween = WorksheetFunction.Max(arrNums)
End Function
Здесь мы используем три аргумента. Первый из них — rngCells As Range. Это диапазон ячеек, в которых нужно искать максимальное значение. Второй и третий аргумент (MinNum, MaxNum) указаны без объявления типа. Это означает, что по умолчанию к ним будет применён тип данных Variant. В VBA используется 6 различных числовых типов данных. Указывать только один из них — это значит ограничить применение функции. Поэтому более целесообразно, если Excel сам определит тип числовых данных.
Цикл For Each … Next последовательно просматривает все значения в выбранном диапазоне. Числа, которые находятся в интервале от максимального до минимального значения, записываются в специальный массив arrNums. При помощи стандартного оператора MAX в этом массиве находим наибольшее число.
С обязательными и необязательными аргументами.
Чтобы понять, что такое необязательный аргумент, вспомните функцию ВПР (VLOOKUP). Её четвертый аргумент [range_lookup] является необязательным. Если вы не укажете один из обязательных аргументов, получите ошибку. Но если вы пропустите необязательный аргумент, всё будет работать.
Но необязательные аргументы не бесполезны. Они позволяют вам выбирать вариант расчётов.
Например, в функции ВПР, если вы не укажете четвертый аргумент, будет выполнен приблизительный поиск. Если вы укажете его как ЛОЖЬ (или 0), то будет найдено точное совпадение.
Если в вашей пользовательской функции есть хотя бы один обязательный аргумент, то он должен быть записан в начале. Только после него могут идти необязательные.
Чтобы сделать аргумент необязательным, вам просто нужно добавить «Optional» перед ним.
Теперь давайте посмотрим, как создать функцию в VBA с необязательными аргументами.
Function GetText(textCell As Range, Optional CaseText = False) As String
Dim StringLength As Integer
Dim Result As String
StringLength = Len(textCell)
For i = 1 To StringLength
If Not (IsNumeric(Mid(textCell, i, 1))) Then Result = Result & Mid(textCell, i, 1)
Next i
If CaseText = True Then Result = UCase(Result)
GetText = Result
End Function
Этот код извлекает текст из ячейки. Optional CaseText = False означает, что аргумент CaseText необязательный. По умолчанию его значение установлено FALSE.
Если необязательный аргумент CaseText имеет значение TRUE, то возвращается результат в верхнем регистре. Если необязательный аргумент FALSE или опущен, результат остается как есть, без изменения регистра символов.
Думаю, что у вас возник вопрос: «Могут ли в пользовательской функции быть только необязательные аргументы?». Ответ смотрите ниже.
Только с необязательным аргументом.
Насколько мне известно, нет встроенной функции Excel, которая имеет только необязательные аргументы. Здесь я могу ошибаться, но я не могу припомнить ни одной такой.
Но при создании пользовательской такое возможно.
Перед вами функция, которая записывает в ячейку имя пользователя.
Function UserName(Optional Uppercase As Variant)
If IsMissing(Uppercase) Then Uppercase = False
UserName = Application.UserName
If Uppercase Then UserName = UCase(UserName)
End Function
Как видите, здесь есть только один аргумент Uppercase, и он не обязательный.
Если аргумент равен FALSE или опущен, то имя пользователя возвращается без каких-либо изменений. Если же аргумент TRUE, то имя возвращается в символах верхнего регистра (с помощью VBA-оператора Ucase). Обратите внимание на вторую строку кода. Она содержит VBA-функцию IsMissing, которая определяет наличие аргумента. Если аргумент отсутствует, оператор присваивает переменной Uppercase значение FALSE.
Можно предложить и другой вариант этой функции.
Function UserName(Optional Uppercase As Variant)
If IsMissing(Uppercase) Then Uppercase = False
UserName = Application.UserName
If Uppercase Then UserName = UCase(UserName)
End Function
В этом случае необязательный аргумент имеет значение по умолчанию FALSE. Если функция будет введена без аргументов, то значение FALSE будет использовано по умолчанию и имя пользователя будет получено без изменения регистра символов. Если будет введено любое значение кроме нуля, то все символы будут преобразованы в верхний регистр.
Возвращаемое значение — массив.
В VBA имеется весьма полезная функция — Array. Она возвращает значение с типом данных Variant, которое представляет собой массив (т.е. несколько значений).
Пользовательские функции, которые возвращают массив, весьма полезны при хранении массивов значений. Например, Months() вернёт массив названий месяцев:
Function Months() As Variant
Months = Array("Январь", "Февраль", "Март", "Апрель", "Май", "Июнь", _
"Июль", "Август", "Сентябрь", "Октябрь", "Ноябрь", "Декабрь")
End Function
Обратите внимание, что функция выводит данные в строке, по горизонтали.
В Office365 и выше можно вводить как обычную формулу, в более ранних версиях – как формулу массива.
А если необходим вертикальный массив значений?
Мы уже говорили ранее, что созданные нами функции можно использовать в формулах Excel вместе со стандартными.
Используем Months() как аргумент функции ТРАНСП:
=ТРАНСП(Months())
Как можно использовать пользовательские функции с массивом данных? Можно применять их для ввода данных в таблицу, как показано на рисунке выше. К примеру, в отчёте о продажах не нужно вручную писать названия месяцев.
Можно получить название месяца по его номеру. Например, в ячейке A1 записан номер месяца. Тогда название месяца можно получить при помощи формулы
=ИНДЕКС(Months();1;A1)
Альтернативный вариант этой формулы:
=ИНДЕКС( {«Январь»; «Февраль»; «Март»; «Апрель»; «Май»; «Июнь»; «Июль»; «Август»; «Сентябрь»; «Октябрь»; «Ноябрь»; «Декабрь»};1;A1)
Согласитесь, написанная нами функция делает формулу Excel значительно проще.
Эта статья откроет серию материалов о пользовательских функциях. Если мне удалось убедить вас, что это стоит использовать или вы хотели бы попробовать что-то новое в Excel, следите за обновлениями;)
MS Excel has many inbuilt in functions that we can use in our formula. If you want to see all the functions by category choose Formulas Tab and then Insert Function. Then Insert function Dialog appears from which we can choose function.
Some important functions of Excel by categories are:
Text Functions
- Lower: Converts all characters in a given text string to lowercase.
- UPPER: Converts all characters in a given text string to uppercase
- CONCATENATE: It will join together two or more text strings
- LEFT: It will return a specified number of characters from the beginning of a supplied text string
- RIGHT: Returns a specified number of characters from the end of a supplied text
Date & Time
- TIME: It will return a time, from a user-given hour, minute, and second.
- NOW: It will return the current date & time
- TODAY: It will return current today’s date.
Statistical
- SUM: It will return the sum of a given list of numbers
- MAX: It will return the largest value from a list of given numbers
- COUNTIF: It will return the number of cells (of a supplied range), that satisfy a given criterion.
Logical
- AND: Tests a number of user-defined conditions and returns TRUE if ALL of the conditions evaluate to TRUE, or FALSE otherwise
- OR: Tests a number of user-defined conditions and returns TRUE if ANY of the conditions evaluate to TRUE, or FALSE otherwise
- NOT: It will return a logical value that is the opposite of a user given logical value or expression i.e. returns FALSE is the given argument is TRUE and returns TRUE if the given argument is FALSE)
Mathematical
- SQRT: It will return the positive square root of a given number
- POWER: It will return the power of a number raised to the second number.
How to Insert a function in Excel
Every function has the same structure. For example, SUM(A1:A4). The name of this function is SUM. The part between the brackets (arguments) means we’re giving Excel the range A1:A4 as input. This function adds the value in cells A1, A2, A3, and A4. It’s not easy to reminder which function and which arguments to use for each task. Fortunately, the Insert Function features in Excel help you with this.
To insert SUM function, need to follow the following steps:
Step 1. Select a cell.
Step 2. Click the Insert Function button. The ‘Insert Function‘ dialog box appears.
Step 3. Look for a function or select a function from a category. For example, choose SUM from the statistical category.
Step 4. Click OK.
The ‘Function Arguments‘ dialog box appears.
Step 5. Click within the Range box and select the range A1:E1.
Step 6. Click OK.
Result: Excel will sum all the number which are present from A1:E1.
To insert MAX function, need to follow the following steps:
Step 1. Select a cell.
Step 2. Click the Insert Function button. The ‘Insert Function‘ dialog box appears.
Step 3. Look for a function or select a function from a category. For example, choose MAX from the statistical category.
Step 4. Click OK. The ‘Function Arguments‘ dialog box appears.
Step 5. Click within the Range box and select the range A1:E1.
Step 6. Click OK
Result: Excel will MAX all the number which are present from B2:E21
To insert COUNT function, need to follow the following steps:
Step 1. Select a cell.
Step 2. Click the Insert Function button. The ‘Insert Function‘ dialog box appears.
Step 3. Look for a function or select a function from a category. For example, choose COUNT from the statistical category.
Step 4. Click OK.
The ‘Function Arguments‘ dialog box appears.
Step 5. Click within the Range box and select the range B2:E2.
Step 6. Click OK.
Result: Excel will COUNT all the number which are present from B2:E2
Чаще всего под формулами в Excel подразумевают именно встроенные функции, предназначенные для выполнения расчетов, и куда реже математические формулы, имеющие уже устоявшийся вид.
В этой статье я рассмотрю обе темы, чтобы каждый пользователь нашел ответ на интересующий его вопрос.
Окно вставки функции
Некоторые юзеры боятся работать в Экселе только потому, что не понимают, как именно устроены функции и каким образом их нужно составлять, ведь для каждой есть свои аргументы и особые нюансы написания. Упрощает задачу наличие окна вставки функции, в котором все выполнено в понятном виде.
-
Для его вызова нажмите по кнопке с изображением функции на панели ввода данных в ячейку.
-
В нем используйте поиск функции, отобразите только конкретные категории или выберите подходящую из списка. При выделении функции левой кнопкой мыши на экране отображается текст о ее предназначении, что позволит не запутаться.
-
После выбора наступает время заняться аргументами. Для каждой функции они свои, поскольку выполняются совершенно разные задачи. На следующем скриншоте вы видите аргументы суммы, которыми являются два числа для суммирования.
-
После вставки функции в ячейку она отобразится в стандартном виде и все еще будет доступна для редактирования.
Комьюнити теперь в Телеграм
Подпишитесь и будьте в курсе последних IT-новостей
Подписаться
Используем вкладку с формулами
В Excel есть отдельная вкладка, где расположена вся библиотека формул. Вы можете использовать ее для быстрого поиска и вставки необходимой функции, а для редактирования откроется то же самое окно, о котором шла речь выше. Просто перейдите на вкладку с соответствующим названием и откройте одну из категорий для выбора функции.
Как видно, их названия тематические, что позволит не запутаться и сразу отобразить тот тип формул, который необходим. Из списка выберите подходящую и дважды кликните по ней левой кнопкой мыши, чтобы добавить в таблицу.
Приступите к стандартному редактированию через окно аргументов функции. Кстати, здесь тоже есть описания, способные помочь быстрее разобраться с принципом работы конкретного инструмента. К тому же ниже указываются доступные значения, которые можно использовать для работы с выбранной формулой.
Ручная вставка формулы в Excel
Опытные пользователи, работающие в Excel каждый день, предпочитают вручную набирать формулы, поскольку так это делать быстрее всего. Они запоминают синтаксис и каждый аргумент, что не только ускоряет процесс, но и делает его более гибким, ведь при использовании одного окна с аргументами довольно сложно расписать большую цепочку сравнений, суммирований и других математических операций.
Для начала записи выделите ячейку и обязательно поставьте знак =, после чего начните вписывать название формулы и выберите ее из списка.
Далее начните записывать аргументы, в чем помогут всплывающие подсказки. По большей части они нужны для того, чтобы не запутаться в последовательности и разделителях.
По завершении нажмите клавишу Enter, завершив тем самым создание формулы. Если все записано правильно, и программе удается рассчитать результат, он отобразится в выбранной ячейке. При возникновении ошибки вы сможете ознакомиться с ее текстом, чтобы найти решение.
Вставка математических формул
В завершение поговорим о математических формулах в Excel, так как тематика статьи подразумевает и вставку таких объектов в таблицу тоже. Доступные уравнения относятся к символам, поэтому для их поиска понадобится перейти на вкладку со вставкой и выбрать там соответствующий раздел.
Из появившегося списка найдите подходящее для вас уравнение или приступите к его ручному написанию, выбрав последний вариант.
На экране появится редактор и блок формулы. Его используйте для перемещения, а сам редактор – для того, чтобы заносить в формулу числа и редактировать ее под себя. Учитывайте, что в этом случае не работают никакие проверки, поэтому правильность написания проверять придется собственноручно.
Это были самые простые способы вставить функции и формулы в Excel. Первые три помогут создать операции, а последний пригодится математикам и тем, кто выполняет сложные расчеты при помощи таблицы и нуждается во вставке математических формул.
В Excel содержится множество встроенных функций, которые могут быть использованы для инженерных, статистических, финансовых, аналитических и прочих расчетов. Иногда условия поставленных задач требуют более гибкого инструмента для поиска решения, тогда на помощь приходят макросы и пользовательские функции.
Пример создания своей пользовательской функции в Excel
Подобно макросам, пользовательские функции могут быть созданы с использованием языка VBA. Для реализации данной задачи необходимо выполнить следующие действия:
- Открыть редактор языка VBA с помощью комбинации клавиш ALT+F11.
- В открывшемся окне выбрать пункт Insert и подпункт Module, как показано на рисунке:
- Новый модуль будет создан автоматически, при этом в основной части окна редактора появится окно для ввода кода:
- При необходимости можно изменить название модуля.
- В отличие от макросов, код которых должен находиться между операторами Sub и End Sub, пользовательские функции обозначают операторами Function и End Function соответственно. В состав пользовательской функции входят название (произвольное имя, отражающее ее суть), список параметров (аргументов) с объявлением их типов, если они требуются (некоторые могут не принимать аргументов), тип возвращаемого значения, тело функции (код, отражающий логику ее работы), а также оператор End Function. Пример простой пользовательской функции, возвращающей названия дня недели в зависимости от указанного номера, представлен на рисунке ниже:
- После ввода представленного выше кода необходимо нажать комбинацию клавиш Ctrl+S или специальный значок в левом верхнем углу редактора кода для сохранения.
- Чтобы воспользоваться созданной функцией, необходимо вернуться к табличному редактору Excel, установить курсор в любую ячейку и ввести название пользовательской функции после символа «=»:
Встроенные функции Excel содержат пояснения как возвращаемого результата, так и аргументов, которые они принимают. Это можно увидеть на примере любой функции нажав комбинацию горячих клавиш SHIFT+F3. Но наша функция пока еще не имеет формы.
Чтобы задокументировать пользовательскую функцию, необходимо выполнить следующие действия:
- Создайте новый макрос (нажмите комбинацию клавиш Alt+F8), в появившемся окне введите произвольное название нового макроса, нажмите кнопку Создать:
- В результате будет создан новый модуль с заготовкой, ограниченной операторами Sub и End Sub.
- Введите код, как показано на рисунке ниже, указав требуемое количество переменных (в зависимости от числа аргументов пользовательской функции):
- В качестве «Macro» должна быть передана текстовая строка с названием пользовательской функции, в качестве «Description» — переменная типа String с текстом описания возвращаемого значения, в качестве «ArgumentDescriptions» — массив переменных типа String с текстами описаний аргументов пользовательской функции.
- Для создания описания пользовательской функции достаточно один раз выполнить созданный выше модуль. Теперь при вызове пользовательской функции (или SHIFT+F3) отображается описание возвращаемого результата и переменной:
Описания функций создавать не обязательно. Они необходимы в случаях, если пользовательские функции будут часто использоваться другими пользователями.
Примеры использования пользовательских функций, которых нет в Excel
Пример 1. Рассчитать сумму отпускных для каждого работника, проработавшего на предприятии не менее 12 месяцев, на основе суммы общей заработной платы и числа выходных дней в году.
Вид исходной таблицы данных:
Каждому работнику полагается 24 выходных дня с выплатой S=N*24/(365-n), где:
- N – суммарная зарплата за год;
- n – число праздничных дней в году.
Создадим пользовательскую функцию для расчета на основе данной формулы:
Код примера:
Public Function Otpusknye(summZp As Long, holidays As Long) As Long
If IsNumeric(holidays) = False Or IsNumeric(summZp) = False Then
Otpusknye = "Введены нечисловые данные"
Exit Function
ElseIf holidays <= 0 Or summZp <= 0 Then
Otpusknye = "Отрицательное число или 0"
Exit Function
Else
Otpusknye = summZp * 24 / (365 - holidays)
End If
End Function
Сохраним функцию и выполним расчет с ее использованием:
=Otpusknye(B3;C3)
Растянем формулу на остальные ячейки с целью получения результатов для остальных работников:
Калькулятор расчета калорий в Excel
Пример 2. Рассчитать суточную норму калорий для участников программы похудения, среди которых есть как женщины, так и мужчины определенного возраста с известными показателями роста и веса.
Вид исходной таблицы данных:
Для расчета используем формулу Миффлина — Сан Жеора, которую запишем в коде пользовательской функции с учетом пола участника. Код примера:
Public Function CaloriesPerDay(sex As String, age As Integer, weight As Integer, height As Integer) As Integer
If sex = "женский" Then
CaloriesPerDay = 10 * weight + 6.25 * height - 5 * age - 161
ElseIf sex = "мужской" Then
CaloriesPerDay = 10 * weight + 6.25 * height - 5 * age + 5
Else: CaloriesPerDay = 0
End If
End Function
Проверки корректности введенных данных упущены для упрощения кода. Если пол не определен, функция вернет результат 0 (нуль).
Пример расчета для первого участника:
=CaloriesPerDay(B3;C3;D3;E3)
В результате использования автозаполнения получим следующие результаты:
Пользовательская функция для решения квадратных уравнений в Excel
Пример 3. Создать функцию, которая возвращает результаты решения квадратных уравнений для указанных в ячейках коэффициентах a, b и c уравнения типа ax2+bx+c=0.
Вид исходной таблицы:
Для решения создадим следующую пользовательскую функцию:
Код примера:
Public Function SquareEquation(a As Integer, b As Integer, c As Integer) As String
Dim answer1 As String
Dim answer2 As String
If a = 0 Then
answer1 = "Единственный корень - "
SquareEquation = answer1 & "(" & -c / b & ")"
ElseIf c = 0 Then
answer1 = "Единственный корень - "
SquareEquation = answer1 & "(" & -b / a & ")"
ElseIf b = 0 And c < 0 Then
answer1 = "Единственный корень - "
SquareEquation = answer1 & "(" & Sqr(a / c) & ")"
ElseIf b ^ 2 - 4 * a * c >= 0 Then
answer1 = "Первый корень - "
answer2 = "Второй корень - "
SquareEquation = answer1 & "(" & (-b + Sqr(b ^ 2 - 4 * a * c)) / (2 * a) & ")" & "; " & _
answer2 & "(" & (-b - Sqr(b ^ 2 - 4 * a * c)) / (2 * a) & ")"
Else:
SquareEquation = "Решений нет"
End If
End Function
Найдем корни первого уравнения:
=SquareEquation(A3;B3;C3)
Выполним расчеты для остальных уравнений. Полученные результаты:
Скачать примеры создания пользовательский функций в Excel
Мы создали свою пользовательскую функцию для расчета квадратных уравнений, которой раньше не было в Excel по умолчанию.
На чтение 14 мин. Просмотров 6.2k.
В Excel более 450 функций, и некоторые из них весьма полезны в вашей повседневной работе.
Но… Excel дает вам возможность создавать пользовательские функции с помощью VBA.
Да — да, вы не ослышались. Пользовательская функция.
И я могу сказать со 100%-ой уверенностью, что каждый начинающий пользователь VBA хочет научиться создавать пользовательские функции. Не так ли? Кивните, если вы один из них.
Итак, сегодня я собираюсь поделиться всем, что вам нужно знать о создании Пользовательской функции.
… так что оставайтесь со мной, вы станете рок-звездой VBA в ближайшие пару минут.
Содержание
- Зачем вам создавать пользовательскую функцию Excel?
- Как создать свою первую пользовательскую функцию в Excel
- Как эта функция работает и возвращает значение в ячейке
- Как улучшить пользовательскую функцию?
- Как использовать пользовательскую функцию VBA
- Различные способы создания пользовательской функции VBA
- Область действия определяемой пользователем функции
- Ограничения пользовательской функции
- Заключение
Зачем вам создавать пользовательскую функцию Excel?
Как я уже сказал, в Excel много функций, которые могут помочь вам решить практически все проблемы и выполнить все виды расчетов. Но…
… Иногда в определенных ситуациях вам нужно создать пользовательскую.
Вот некоторые причины, почему вам нужно перейти к пользовательской функции.
1. Когда нет подходящей функции
Иногда бывает, что вам нужно что-то вычислить, и для этого нет подходящей встроенной функции.
Например, подсчет слов в ячейке, в этом случае пользовательская функция — идеальное решение.
Function MyWordCount(rng As Range) As Integer MyWordCount = UBound(Split(rng.Value, " "), 1) + 1 End Function
2. Заменить сложную формулу
Если вы работаете с формулами, то вы знаете, что сложные формулы бывает трудно читать самому, а другим пользователем еще сложнее.
Пользовательская функция может решить эту проблему.
Такая функция поможет вам избежать долгих вычислений. Как только вы создадите функцию, вам не нужно будет писать эту сложную формулу снова и снова.
3. Когда вы не хотите использовать SUB
Хотя вы можете использовать код VBA для выполнения расчетов, но коды VBA не динамические.
Вам нужно снова запустить этот код, если вы хотите обновить свой расчет.
Но если вы преобразуете этот код в функцию, вам не нужно будет запускать этот код снова и снова.
Как создать свою первую пользовательскую функцию в Excel
Обычно для создания функции VBA необходимо выполнить следующие шаги:
- Объявить вашу процедуру как функцию
- Определить ее аргументы и их тип данных
- Добавить код для расчета желаемого значения
Позвольте мне привести вам простой пример.
Вам необходимо создать функцию, которая может возвращать название дня недели из значения даты.
Да, у нас есть функция, которая возвращает номер дня недели, но не название.
Итак, давайте создадим эту функцию VBA, используя следующие шаги.
- Прежде всего, откройте редактор VB с помощью сочетания клавиш ALT + F11 или перейдите на вкладку «Разработчик» и нажмите кнопку «Visual Basic».
- Вставка модуля: щелкните правой кнопкой мыши в окне проекта VBA, затем перейдите к Insert и после этого нажмите «Module».
- Следующим шагом является определение имени для функции, здесь я использую «myDayName». Поэтому вы должны написать «Function mydayName».
Почему «Function» перед именем?
Поскольку вы создаете функцию VBA, то используете слово «Function». Excel понимает, что этот код следует рассматривать как функцию
- После этого вам нужно определить аргументы для пользовательской функции. Поэтому вставьте начальные скобки и напишите «InputDate As Date».
- Здесь InputDate — имя аргумента, а date — его тип данных. Всегда лучше определить тип данных для аргумента.
- Теперь закройте скобки и напишите «As String». Здесь вы определяете тип данных результата, возвращаемого функцией. Так как вы хотите, чтобы название дня недели было текстовым, его тип данных должен быть «String».
- В конце нажмите ENTER.
На этом этапе имя вашей функции, ее аргумент, тип данных аргумента и тип данных функции определены, и у вы должны видеть что-то вроде этого в вашем модуле:
Теперь между «Function» и «End Function» вам нужно сделать расчет.
В Excel есть функция рабочего листа под названием «Text», давайте используем ее здесь. Для этого вам нужно написать следующий код:
myDayName = WorksheetFunction.Text (InputDate, "dddddd")
С помощью этого кода вы определяете значение, которое должно быть возвращено функцией.
- Теперь закройте редактор VB и вернитесь к рабочему листу.
- В ячейке B2 введите «= myDayName (A2)», нажмите Enter, и у вы увидите название дня недели.
Поздравляю! Вы только что создали свою первую пользовательскую функцию!
Как эта функция работает и возвращает значение в ячейке
Вы создали свою первую пользовательскую функцию, но дело в том, что нужно еще понять, как она работает.
Можно сказать в двух словах, это код VBA, но мы используем его как функцию. Давайте разбираться.
- Вы вводите код в ячейку как функцию и указываете ссылку на ячейку
- Excel запускает код функции и использует значение, которое вы указали
- Вы получаете результат в ячейке
А теперь детали: в тот момент, когда вы вводите код в ячейку и ссылаясь на другую, код выполняется, используя указанное вами значение для возврата результата.
Давайте чуть медленнее:
Есть код для функции, которую мы создали, и вы знаете, что в этом коде. Правильно?
Когда вы ссылаетесь на ячейку в вашей функции, этот блок кода работает для вычисления значения. Он берет дату из аргумента InputDate и возвращает название дня недели.
Важно: когда вы пишете код для пользовательской функции, вам нужно позаботиться о том, чтобы значение, возвращаемое этим кодом, было присвоено имени функции.
Как улучшить пользовательскую функцию?
Вы уже знаете, как создать пользовательскую функцию VBA. Но…
Есть одна вещь, о которой вы должны позаботиться: код, который вы используете должен быть достаточно хорош, чтобы использовать все возможности.
Если говорить о функции, которую вы только что написали выше, да вы можете вернуть название дня недели из даты. Но… Что если указанное вами значение не будет датой? А если указанная вами ячейка пуста?
Могут быть и другие проблемы, но я уверен, что вы поняли, о чем я.
Итак, давайте попробуем улучшить эту пользовательскую функцию, чтобы она смогла справиться с вышеуказанными проблемами.
Прежде всего, вам нужно изменить тип данных аргумента и использовать:
Так ваша пользовательская функция сможет принимать любой тип данных в качестве входных данных.
Далее нам нужно использовать оператор VBA IF, чтобы проверить InputDate для некоторых условий. Первое условие — пустая ячейка или нет. И для этого вам нужно использовать следующий код:
If InputDate = "" Then myDayName = ""
Функция ничего не будет возвращать, если указанная вами ячейка будет пустой. Одна проблема решена, давайте перейдем к следующей.
Помимо даты есть возможности, что значение может быть числом или текстом. Поэтому необходимо создать условие, которое будет проверять, является ли указанное значение действительной датой или нет. Код такой:
If IsDate (InputDate) = False Then myDateName = ""
Примечание. Здесь я использую пробел для обоих условий, чтобы при наличии больших данных можно было легко отфильтровать значения, если входное значение недопустимо.
Таким образом, после добавления вышеуказанных условий код будет выглядеть так:
Функция myDayName (InputDate As Variant) в виде строки
Function myDayName(InputDate As Variant) As String If InputDate = "" Then myDayName = "" Else If IsDate(InputDate) = False Then myDateName = "" Else myDayName = WorksheetFunction.Text(InputDate, "dddddd") End If End If End Function
Я думаю, что вы можно внести еще некоторые изменения в эту функцию, но я уверен, что суть вы уловили.
Как использовать пользовательскую функцию VBA
Научившись создавать функцию VBA в Excel, нужно узнать, как вы можете ее использовать. И в этой части статьи я расскажу вам, как и где вы можете это делать.
Итак, давайте начнем.
1. На рабочем листе
Почему мы создаем пользовательскую функцию? Чтобы использовать ее на рабочем листе. Вы можете просто использовать ПФ на листе, используя знак равенства и введя имя функции, а затем указав ее аргументы.
Вы также можете ввести пользовательскую функцию из библиотеки функций.
Перейдите на вкладку «Формулы» ➜ «Вставить функцию» ➜ «Определенные пользователем».
Из списка можно выбрать функцию, которую хотите вставить.
2. Использование в других подпроцедурах и функциях
Вы также можете использовать функцию в других функциях или в процедуре «Sub».
Ниже приведен код VBA, в котором мы использовали функцию, чтобы получить название дня недели для текущей даты.
Sub todayDay() MsgBox "Сегодня " & myDayName(Date) End Sub
3. Доступ к функциям из другой книги
Если у вас есть ПФF в одной рабочей книге и вы хотите использовать его в другой или во всех рабочих книгах, вы делаете это путем создания надстройки для нее. Выполните следующие простые шаги:
- Прежде всего, вам нужно сохранить файл (в котором у вас есть код пользовательской функции) в виде надстройки.
- Для этого перейдите на вкладку «Файл» ➜ «Сохранить как» ➜ «Надстройки Excel (.xalm)».
- После этого дважды щелкните на надстройку и установите ее.
- нажмите добавить, чтобы добавить все определенные пользователем функции в другую книгу
Теперь вы можете использовать все свои функции VBA в любой книге.
Различные способы создания пользовательской функции VBA
Когда мы используем встроенные функции, они имеют разные типы аргументов. В этом разделе руководства вы узнаете, как создать ПФ с аргументами другого типа.
- без каких-либо аргументов
- только с одним аргументом
- с несколькими аргументами
- использование массива в качестве аргумента
1. Без каких-либо аргументов
Помните есть такие функции, как СЕЙЧАС и СЕГОДНЯ, в которых вам не нужно вводить какие-либо аргументы? Вы можете создать пользовательскую функцию, в которой вам тоже не нужно вводить аргумент. Сделаем это на примере:
Давайте создадим пользовательскую функцию, которая может возвращать местоположение текущего файла.
Вот код:
Function myPath() As String Dim myLocation As String Dim myName As String myLocation = ActiveWorkbook.FullName myName = ActiveWorkbook.Name If myLocation = myName Then myPath = "Файл еще не сохранен." Else myPath = myLocation End If End Function
Эта функция возвращает путь к месту, где хранится текущий файл, и, если рабочая книга нигде не сохранена, будет отображаться сообщение «Файл еще не сохранен».
Теперь, если вы обратите пристальное внимание на код этой функции, вы не увидите ни одного аргумента (в скобках). Вы определяете тип данных для результата функции. Основное правило создания функции без аргументов — это код, в который вам не нужно ничего вводить. Проще говоря, значение, которое вы хотите получить взамен функции, должно вычисляться автоматически.
Этот код «ActiveWorkbook.FullName» возвращает местоположение файла, а этот «ActiveWorkbook.Name» возвращает имя. Так что здесь вам не нужно ничего вводить.
2. Только с одним аргументом
Мы уже рассмотрели эту ситуацию, изучая, как создать пользовательскую функцию. Но давайте копнем немного глубже и создадим другую функцию.
Это функция нужна для извлечения URL-адреса из гиперссылки.
Function giveMeURL(rng As Range) As String On Error Resume Next giveMeURL = rng.Hyperlinks(1).Address End Function
В этой функции у вас есть только один аргумент.
Когда вы напишите функцию, а затем укажите ячейку, в которой у вас есть гиперссылка, она вернет URL-адрес.
Теперь в этой функции основная работа выполняется:
rng.Hyperlinks (1) .Address
rng - это то, что вам нужно указать.
3. С несколькими аргументами
Обычно большинство встроенных функций Excel имеют несколько аргументов. Поэтому вам необходимо узнать, как создать пользовательскую функцию с несколькими аргументами. Давайте рассмотрим пример:
Вы хотите удалить определенные буквы из текстовой строки и получить оставшуюся часть. У вас есть такие функции, как RIGHT и LEN, которые вы собираетесь использовать в этой пользовательской функции. Но здесь они нам не понадобятся. Все, что нам нужно, это пользовательская функция, использующая VBA.
Итак, вот функция:
Function removeFirstC(rng As String, cnt As Long) As String removeFirstC = Right(rng, Len(rng) - cnt) End Function
Итак, посмотрим:
В этой функции у вас два аргумента:
- rng: в этом аргументе вам нужно указать ячейку, из которой вы хотите удалить символ текста.
- cnt: а в этом аргументе вам нужно указать количество символов для удаления (если вы хотите удалить более одного символа из текста).
Когда вы вводите ее в ячейку, она работает примерно так:
3.1 Создание пользовательской функции с необязательным и обязательным аргументом
Если говорить о функции, которую мы только что создали в приведенном выше примере, где у нас было два разных аргумента, то они оба обязательны. Если вы пропустите любой из них, вы получите такую ошибку.
Но можно сделать этот аргумент необязательным, чтобы он принимал значение по умолчанию. Чтобы сделать аргумент необязательным, вам просто нужно добавить «Optional» перед ним.
4. Использование массива в качестве аргумента
Есть несколько встроенных функций, которые могут принимать аргументы в виде массива, также вы можете сделать свою собственную функцию VBA. Давайте рассмотрим простой пример: вам нужно создать функцию, в которой вы суммируете значения из диапазона, в котором у вас есть числа и текст.
Function addNumbers(CellRef As Range) Dim Cell As Range For Each Cell In CellRef If IsNumeric(Cell.Value) = True Then Result = Result + Cell.Value End If Next Cell addNumbers = Result End Function
В приведенном выше коде функции мы использовали весь диапазон A1: A10 вместо одного значения или ссылки на ячейку.
Используем цикл FOR EACH, он проверяет каждую ячейку диапазона и суммирует значение, если в ячейке есть число.
Область действия определяемой пользователем функции
Проще говоря, область действия функции означает, может ли она вызываться из других процедур или нет. UDF может иметь два разных типа областей действия:
1. Public
Вы можете сделать свою пользовательскую функцию общедоступной, чтобы ее можно было вызывать во всех рабочих листах рабочей книги. Для этого вам просто нужно использовать слово «Public», как показано ниже.
Функция является Public по умолчанию, если вы не делаете ее Private. Во всех приведенных нами примерах все функции общедоступны.
2. Private
Когда вы делаете функцию Private, вы можете использовать ее в процедурах того же модуля.
Допустим, если у вас есть функция в «Module1», вы можете использовать ее только в процедурах, которые вы используете в «Module1». И она не появится в списке функций на рабочем листе (когда вы используете знак = и пытаетесь ввести имя), но вы все равно можете использовать ее, введя ее название полностью и указав аргументы.
Ограничения пользовательской функции
Пользовательские функции супер полезны. Но они ограничены в некоторых ситуациях. Вот несколько вещей, которые нужно записать и запомнить при создании пользовательской функции в VBA:
- Вы не можете изменять, удалять или форматировать ячейки и диапазон с помощью пользовательской функции.
- Также нельзя перемещать, переименовывать, удалять или добавлять рабочие листы в рабочую книгу.
- Не сможете вносить изменения в значение другой ячейки.
Есть ли разница между встроенной функцией и пользовательской функцией?
Чтобы ответить на этот вопрос, я хочу поделиться некоторыми моментами, которые, на мой взгляд, важны.
- Медленнее, чем встроенная. Если вы сравните скорость встроенных функций и функции VBA, вы обнаружите, что первые быстрее. Причина в том, что встроенные функции написаны с использованием C ++ или FORTRAN.
- Трудно обмениваться файлами. Мы часто обмениваемся файлами по электронной почте и в облаке, поэтому, если вы используете какую-либо из пользовательских функций, вам необходимо поделиться этим файлом в формате «xlam», чтобы другой человек также мог использовать вашу пользовательскую функцию.
Но все равно, есть ситуации, когда пользовательские функции будут незаменимы.
Заключение
Создать пользовательскую функцию просто.
Все, что вам нужно сделать, это использовать «Function» перед названием, чтобы определить его как функцию, добавить аргументы, определить тип данных аргументов, а затем определить тип данных для возвращаемого значения.
В конце добавьте код, чтобы вычислить значение, которое вы хотите получить от функции.
Это самое простое руководство, как создать пользовательскую функцию в VBA, и я надеюсь, вы нашли ее полезной.
Перейти к содержанию
На чтение 3 мин Опубликовано 14.12.2019
В этом уроке вы узнаете, как вставить функцию в Excel с помощью команды Автосумма, а также вводя ее вручную. Это лишь малая часть способов, которые позволяют вставить функцию. На самом деле их достаточно много, остальные мы разберем в следующих уроках. Итак, если Вы хотите узнать, как вставляется функция в Excel, читайте урок до конца.
Прежде чем говорить о том, как вставить функцию в Excel, познакомимся с некоторыми наиболее распространенными и часто используемыми функциями:
- СУММ – эта функция суммирует значения всех аргументов.
- СРЗНАЧ – определяет среднее арифметическое величин, содержащихся в аргументах. Функция вычисляет сумму значений ячеек, а затем делит результат на их количество.
- СЧЁТ – подсчитывает количество чисел в списке аргументов. Функция полезна для быстрого подсчета числа элементов в диапазоне.
- МАКС – определяет максимальное значение из списка аргументов.
- МИН – определяет минимальное значение из списка аргументов.
Как вставить функцию в Excel
В следующем примере мы создадим простую формулу для расчета средней цены за единицу заказанных товаров, используя функцию СРЗНАЧ.
- Выделите ячейку, в которую необходимо вставить формулу. В нашем примере мы выделим ячейку C11.
- Введите знак равенства (=) и нужное имя функции. Вы также можете вставить функцию из списка, который появится при вводе ее названия (автозавершение в Excel). В нашем случае мы введем =СРЗНАЧ.
- Введите диапазон ячеек в качестве аргумента в круглых скобках. В нашем примере мы введем (C3:C10). Эта формула суммирует значения в диапазоне С3:С10, а затем делит результат на количество ячеек в этом диапазоне, тем самым определяя среднее значение.
- Нажмите Enter на клавиатуре. Функция будет вычислена, и Вы увидите результат. В данном примере средняя цена за единицу заказанных товаров составила $15,93.
Excel не всегда предупреждает об ошибке в формуле, поэтому Вам необходимо проверять их самостоятельно. Чтобы узнать, как это можно сделать, изучите урок Двойная проверка формул в Excel.
Вставка функции с помощью команды Автосумма
Команда Автосумма позволяет автоматически вставлять наиболее распространенные функции в формулы Excel, включая СУММ, СРЗНАЧ, СЧЁТ, МИН и МАКС. В следующем примере мы создадим формулу для расчета полной стоимости недавно заказанных товаров, используя функцию СУММ.
- Выделите ячейку, в которую необходимо вставить формулу. В нашем примере мы выделим ячейку D12.
- В группе команд Редактирование на вкладке Главная найдите и нажмите стрелку рядом с командой Автосумма, а затем выберите нужную функцию в раскрывающемся меню. В нашем случае мы выберем Сумма.
- Выбранная функция появится в ячейке. Команда Автосумма автоматически определяет диапазон ячеек для аргумента. В данном примере диапазон D3:D11 был выбран автоматически, а значения просуммированы, чтобы вычислить полную стоимость. Вы также можете вручную ввести нужный диапазон.
- Нажмите Enter на клавиатуре. Функция будет вычислена, и Вы увидите результат. В нашем примере сумма значений диапазона D3:D11 составляет $606,05.
В Microsoft Excel команду Автосумма можно также найти на вкладке Формулы.
Оцените качество статьи. Нам важно ваше мнение:
Загрузить PDF
Загрузить PDF
Хотя в Excel множество (возможно, сотни) встроенных функций, таких как SUM (СУММ), VLOOKUP (ВПР), LEFT (ЛЕВСИМВ) и других, как только вы начинаете использовать Excel для более сложных задач, вы можете обнаружить, что вам нужна такая функция, которой еще не существует. Не отчаивайтесь, вы всегда можете создать функцию сами.
Шаги
-
1
Создайте новую книгу Excel или откройте книгу, в которой хотите использовать пользовательскую функцию (UDF).
-
2
Откройте редактор Visual Basic, который встроен в Microsoft Excel, выбрав «Инструменты»->«Макросы»->«Редактор Visual Basic» (или нажав Alt+F11).
-
3
Добавьте новый модуль в свою книгу Excel, нажав на указанную кнопку. Вы можете создать пользовательскую функцию на рабочем листе без добавления нового модуля, но в таком случае вы не сможете использовать эту функцию на других листах книги.
-
4
Создайте «заголовок» или «прототип» вашей функции. Он должен иметь следующую структуру:
public function TheNameOfYourFunction (param1 As type1, param2 As type2 ) As returnType У нее может быть сколько угодно параметров, а их тип должен соответствовать любому базовому типу данных Excel или типу объектов, например Range. Параметры в данном случае выступают в качестве «операндов», с которыми работает функция. Например, если вы пишете SIN(45), чтобы вычислить синус 45 градусов, 45 выступает в качестве параметра. Код вашей функции будет использовать это значение для вычислений и представления результата.
-
5
Добавьте код нужной функции, убедившись, что вы 1) используете значения, передаваемые в качестве параметров; 2) присваиваете результат имени функции; 3) заканчиваете код функции выражением «end function». Изучение программирования на VBA или на любом другом языке может занять некоторое время и требовать подробного изучения руководства. Однако функции обычно имеют небольшие блоки кода и используют очень мало возможностей языка. Наиболее используемые элементы языка VBA:
- Блок If, который позволяет выполнять какую-то часть кода только в случае выполнения условия. Например:
Public Function Course Result(grade As Integer) As String
If grade >= 5 Then
CourseResult = "Approved"
Else
CourseResult = "Rejected"
End If
End FunctionОбратите внимание на элементы внутри блока If:
IF условие THEN код_1 ELSE код_2 END IF
. Ключевое слово Else и вторая часть кода необязательны. - Блок Do, который выполняет часть кода, пока выполняется условие (While) или до тех пор (Until), пока оно не выполнится. Например:
Public Function IsPrime(value As Integer) As Boolean
Dim i As Integer
i = 2
IsPrime = True
Do
If value / i = Int(value / i) Then
IsPrime = False
End If
i = i + 1
Loop While i < value And IsPrime = True
End FunctionОбратите внимание на элементы:
DO код LOOP WHILE/UNTIL условие
. Обратите также внимание на вторую строку, где «объявлена» переменная. В своем коде вы можете добавлять переменные и позже их использовать. Переменные служат для хранения временных значений внутри кода. И наконец, обратите внимание, что функция объявлена как BOOLEAN, что является типом данных, в котором допустимы только значения TRUE и FALSE. Этот способ определения, является ли число простым, далеко не самый оптимальный, но мы оставили его таким, чтобы сделать код более читабельным. -
Блок For , который выполняет часть кода указанное число раз. Например:
Public Function Factorial(value As Integer) As Long
Dim result As Long
Dim i As Integer
If value = 0 Then
result = 1
ElseIf value = 1 Then
result = 1
Else
result = 1
For i = 1 To value
result = result * i
Next
End If
Factorial = result
End FunctionОбратите внимание на элементы:
FOR переменная = начальное_значение TO конечное_значение код NEXT
. Также обратите внимание на элемент ElseIf в выражении If, который позволяет добавить больше условий к коду, который нужно выполнить. И наконец, обратите внимание на объявление функции и переменной «result» как Long. Тип данных Long позволяет хранить значения, намного превышающие Integer.Ниже показан код функции, преобразующей небольшие числа в слова.
- Блок If, который позволяет выполнять какую-то часть кода только в случае выполнения условия. Например:
-
6
Перейдите обратно в рабочую книгу Excel и используйте свою функцию, набрав в какой-либо ячейке знак равно, а затем имя функции. Добавьте к имени функции открывающую скобку, параметры, разделенные запятыми, и закрывающую скобку. Например:
=NumberToLetters(A4)
Вы также можете использовать свою пользовательскую функцию, найдя ее в категории Пользовательские в мастере вставки формулы. Просто нажмите на кнопку Fx, расположенную слева от поля формул. Параметры могут быть трех типов:
- Константные значения, непосредственно вводимые в формуле в ячейке. Текстовые строки в таком случае должны быть заключены в кавычки.
- Ссылки на ячейки вроде B6 или ссылки на диапазоны вроде A1:C3 (параметр должен иметь тип Range).
- Другие вложенные функции (ваша функция тоже может быть вложенной по отношению к другим функциям). Например: =Factorial(MAX(D6:D8))
-
7
Убедитесь, что результат функции правильный при нескольких ее срабатываниях, чтобы удостовериться, что она правильно обрабатывает различные значения параметров.
Реклама
Советы
- Всякий раз, когда вы пишете блок кода внутри структуры If, For, Do и так далее, убедитесь, что вы он имеет отступ, который можно сделать с помощью пробелов или знаков табуляции (стиль отступов вы выбираете сами). Это сделает ваш код более читабельным, и вам самим потом легче будет отслеживать ошибки и вносить изменения.
- Используйте имя, которое еще не используется в качестве имени функции в Excel, иначе вы сможете использовать только одну из этих функций.
- Excel имеет множество встроенных функций, и большинство вычислений можно сделать с помощью независимого их использования или с использованием их комбинаций. Прежде чем писать свою функцию, пройдитесь по всему списку уже существующих функций. При использовании встроенных функций выполнение может происходить быстрее.
- В некоторых случаях для вычисления результата функции необязательно знать все значения параметров. В подобных случаях вы можете использовать ключевое слово Optional перед именем параметра в заголовке функции. В коде вы можете использовать функцию IsMissing(имя_параметра), чтобы определить, было ли параметру присвоено какое-то значение или нет.
- Если вы не знаете, как написать код функции, прочитайте статью о том, как написать простейший макрос в Microsoft Excel.
Реклама
Предупреждения
- В связи с определенными мерами безопасности некоторые люди могут отключить макросы. Обязательно известите своих коллег о том, что книга Excel, которую вы им посылаете, содержит макросы, и что эти макросы не навредят их компьютерам.
- Примеры функций, использованных в этой статье, — необязательно самый лучший способ решить связанные с ними проблемы. Эти функции были использованы, чтобы наглядно показать использование контрольных структур языка.
- VBA, как и многие другие языки, имеет еще несколько контрольных структур кроме Do, If и For. Эти структуры были приведены здесь, чтобы объяснить, что можно делать внутри кода функций. В интернете есть множество учебников, по которым вы можете изучить VBA.
Реклама
Об этой статье
Эту страницу просматривали 56 756 раз.
Была ли эта статья полезной?
Формулы и функции в Excel
- Смотрите также
- 12. По математике
- Принимает до 255 аргументов
- Эйлера в Excel.
- В диалоговом окне
книги, необходимо ввести функции код дляDiscount = quantity *End If помогают в тех вид:
Оператор функций, перейдя во вложенных функций ЕСЛИ) будет вставлен автоматически.Statistical ячейкиВвод формулы для поступления нужно в виде условий
Пример применения функцииНадстройки=personal.xlsb!discount() таких действий, возникнет price * 0.1DISCOUNT = Application.Round(Discount, случаях, когда нужно=ABS(число)
СУММЕСЛИ
вкладку
Ввод формулы
для назначения буквенныхВ поле
- (Статистические).
- A1Редактирование формул получить не менее или ссылок. Обязательным
- EXP в лабораторныхнажмите кнопку «Обзор»,, а не просто ошибка #ЗНАЧ!Результат хранится в виде 2) производить массовые расчеты.
Урок:также подсчитывает общую«Формулы» категорий числовым результатамКатегорияНажмите.Приоритет операций 4 баллов. Составить является первый. исследованиях и анализах. найдите свою надстройку,
- =discount()Единственное действие, которое может переменной
End FunctionАвтор: Максим ТютюшевФункция модуля в Excel сумму чисел в. Там нужно нажать тестирования.
Редактирование формул
выберите пунктОККогда вы копируете формулу,Копировать/Вставить формулу отчет о поступлении.
-
- ИЛИ Применение функции EXP нажмите кнопку
- . выполнять процедура функцииDiscount
Приоритет операций
Примечание:Хотя в Excel предлагаетсяИз названия понятно, что ячейках. Но, в на кнопкуСкопируйте образец данных изВсе. Появится диалоговое окно Excel автоматически подстраиваетВставка функцииСоставим таблицу с исходными
Показывает результат «ИСТИНА», если для финансовых расчетовОткрытьЧтобы вставить пользовательскую функцию (кроме вычислений), —. Оператор VBA, который
Чтобы код было более
большое число встроенных задачей оператора отличие от предыдущей«Вставить функцию» следующей таблицы и.Function Arguments ссылки для каждойФормула представляет собой выражение,
Копировать/вставить формулу
данными: хотя бы один при анализе вложений, а затем установите быстрее (и избежать это отображение диалогового хранит значение в
- удобно читать, можно функций, в немСТЕПЕНЬ функции, в данном
- , расположенную на самом вставьте их вЕсли вы знакомы с(Аргументы функции). новой ячейки, в которое вычисляет значениеНужно общее количество баллов из аргументов является инвестиций на депозитные флажок рядом с
- ошибок), ее можно окна. Чтобы получить переменной, называется оператором добавлять отступы строк может не бытьявляется возведение числа операторе можно задать левом краю ленты ячейку A1 нового категориями функций, можноКликните по кнопке справа которую копируется формула.
- ячейки. Функции – сравнить с проходным истинным. счета в банк. надстройкой в поле выбрать в диалоговом значение от пользователя,назначения с помощью клавиши той функции, которая в заданную степень. условие, которое будет в блоке инструментов листа Excel. Чтобы
также выбрать категорию. от поля Чтобы понять это, это предопределенные формулы баллом. И проверить,=ИЛИ (Лог_знач.1; Лог_знач. 2;…)Примеры формул с функциями
Вставка функции
Доступные надстройки окне «Вставка функции».
выполняющего функцию, можно
, так как он
TAB нужна для ваших У данной функции определять, какие именно«Библиотека функций» отобразить результаты формул,Если вы не знаете,Range выполните следующие действия: и они уже чтобы по математике——-//——- ИНДЕКС и ПОИСКПОЗ. Пользовательские функции доступны использовать в ней вычисляет выражение справа. Отступы необязательны и вычислений. К сожалению, два аргумента: значения участвуют в. выделите их и какую функцию использовать,(Диапазон) и выберитеВведите формулу, показанную ниже,
встроены в Excel. оценка была не
- НЕ
- СУММПРОИЗВ в Excel.После выполнения этих действий в категории «Определенные
оператор
- от знака равенства не влияют на разработчики Excel не«Число» расчете, а какиеСуществует и третий способ нажмите клавишу F2, можно ввести вопрос,
- диапазон в ячейкуНапример, на рисунке ниже ниже «4». ВМеняет логическое значение «ИСТИНА»
- Примеры использования массивных ваши пользовательские функции пользователем»:InputBox и назначает результат выполнение кода. Если могли предугадать все
- и нет. При указании активации Мастера функций. а затем — клавишу
- описывающий необходимые действия,A1:C2A4
ячейка графе «Результат» поставить на противоположное – функций ИНДЕКС и
будут доступны при
Чтобы упростить доступ к
. Кроме того, с имени переменной слева добавить отступ, редактор потребности пользователей. Однако«Степень» условия можно использовать Он осуществляется с ВВОД. При необходимости в поле
..
А3
«принят» или «нет».
«ЛОЖЬ». И наоборот.
office-guru.ru
Использование вложенных функций в формуле
ПОИСКПОЗ, СУММПРОИЗВ как каждом запуске Excel. пользовательским функциям, можно помощью оператора от него. Так Visual Basic автоматически в Excel можно. Первый из них знаки «>» («больше»), помощью нажатия комбинации измените ширину столбцов,Поиск функцииКликните в полеВыделите ячейкусодержит формулу, котораяВведем формулу вида: =4;СУММ(B3:D3)>=$B$1);»принят»;»нет»)’#ИМЯ? альтернатива формулам массива. Если вы хотите определить их вMsgBox как переменная
вставит его и создавать собственные функции, может быть указан «» («не равно»). клавиш на клавиатуре чтобы видеть все(например, при вводеCriteriaА4 складывает значения ячеек class=’formula’>. Логический операторОбычно сочетается с другими Формулы для поиска добавить функции в отдельной книге, аможно выводить сведенияDiscount для следующей строки. и ниже вы в виде ссылки
То есть, число,Shift+F3 данные.
«добавить числа» возвращается(Критерий) и введите, кликните по ней
А2 «И» заставляет функцию
-
операторами. значений по столбцам
-
библиотеку, вернитесь в затем сохранить ее для пользователей. Выназывается так же, Чтобы сдвинуть строку
найдете все нужные на ячейку, содержащую которое не соответствует
-
.Оценка функция «>5». правой кнопкой мыши
и проверять истинность двухЕСЛИ
таблицы. редактор Visual Basic. как надстройку, которую также можете использовать как и процедура на один знак для этого инструкции. числовую величину. Второй заданному условию, воПосле того, как пользователь45
-
СУММНажмите и выберите командуA1
условий. Математическая функцияПроверяет истинность логического выраженияФункция РИМСКОЕ в Excel В обозревателе проектов можно включать при
настраиваемые диалоговые окна функции, значение, хранящееся табуляции влево, нажмитеПользовательские функции (как и аргумент указывается степень втором аргументе при произвел любое из90).OKCopy. «СУММ» используется для и возвращает соответствующий для перевода арабских под заголовком VBAProject каждом запуске Excel. (
-
в переменной, возвращаетсяSHIFT+TAB
макросы) записываются на возведения. Из всего подсчете суммы в вышеуказанных действий, открывается78Чтобы ввести другую функцию.(Копировать) или нажмитеЕщё один пример. Ячейка подсчета итогового балла. результат. чисел в римские. вы увидите модуль
Вот как этоUserForms в формулу листа,. языке программирования вышесказанного следует, что расчет не берется.
-
Мастер функций. КликаемФормула в качестве аргумента,Результат:
-
сочетание клавишA3
-
Функция ЕСЛИ позволяет решать#ИМЯ?Примеры использования функции с таким же сделать:
-
), но эта тема из которой былаТеперь вы готовы использоватьVisual Basic для приложений синтаксис этого оператора Кроме того, существует
по окну вОписание введите функцию в
-
Excel подсчитывает числоCtrl+Cсодержит функцию многочисленные задачи, поэтому«Логическое_выражение» при вычислении должно РИМСКОЕ в переводе
-
названием, как уWindows macOS
-
выходит за рамки вызвана функция DISCOUNT.
Примеры
новую функцию DISCOUNT. (VBA) имеет следующий вид: дополнительный аргумент поле
Результат поле этого аргумента. ячеек, значение которых.SUM используется чаще всего. иметь результат «ИСТИНА» арабских чисел в файла надстройки (ноСоздав нужные функции, выберите данной статьи.Если значение Закройте редактор Visual
. Они отличаются от |
||
=СТЕПЕНЬ(число;степень) |
||
«Диапазон суммирования» |
||
«Категория» |
||
’=ЕСЛИ(A2>89,»A»,ЕСЛИ(A2>79,»B», ЕСЛИ(A2>69,»C»,ЕСЛИ(A2>59,»D»,»F»)))) |
Части формулы, отображенные в |
больше 5. |
Далее выделите ячейку |
(СУММ), которая вычисляетЗадача 1. Проанализировать стоимость или «ЛОЖЬ». римские цифры. Как |
без расширения XLAM). |
Файл |
Даже простые макросы иquantity Basic, выделите ячейку макросов двумя вещами. |
Урок: |
, но он не |
.Использует вложенные функции ЕСЛИ диалоговом окне=COUNTIF(A1:C2;»>5″) |
B4 |
сумму диапазона товарных остатков после
-
ЕСЛИОШИБКА переводить, преобразовать, конвертироватьДважды щелкните модуль в>
-
пользовательские функции можетменьше 100, VBA G7 и введите Во-первых, в нихКак возводить в степень
support.office.com
10 популярных математических функций Microsoft Excel
является обязательным. ДаннаяОткрывается выпадающий список. Выбираем для назначения буквеннойАргументы функции=СЧЁТЕСЛИ(A1:C2;»>5″), кликните по нейA1:A2 уценки. Если ценаЕсли значение первого аргумента и заменить арабские Project Explorer, чтобыСохранить как быть сложно понять. выполняет следующий оператор: следующий код: используются процедуры
в Экселе операция имеет следующий
Применение математических функций
в нем позицию категории оценке в, отображают функцию, выбраннуюПримечание: правой кнопкой мыши. продукта после переоценки истинно, то возвращает цифры римскими? вывести код функций.. Чтобы сделать эту
Discount = 0=DISCOUNT(D7;E7)FunctionЗадачей функции синтаксис:«Математические» ячейке A2. на предыдущем шаге.Вместо того, чтобы и выберите команду=SUM(A1:A2) ниже средних значений, сам аргумент. ВФункция КПЕР для расчета Чтобы добавить новуюВ Excel 2007 нажмите
задачу проще, добавьтеНаконец, следующий оператор округляетExcel вычислит 10%-ю скидку, а неКОРЕНЬ=СУММЕСЛИ(Диапазон;Критерий;Диапазон_суммирования).=ЕСЛИ(A2>89;»A»;ЕСЛИ(A2>79;»B»; ЕСЛИ(A2>69;»C»;ЕСЛИ(A2>59;»D»;»F»))))Если щелкнуть элемент использовать инструмент «Insert=СУММ(A1:A2)
то списать со противном случае – количества периодов погашений функцию, установите точкукнопку Microsoft Office комментарии с пояснениями. значение, назначенное переменной
для 200 единицSubявляется извлечение квадратногоКак можно понять изПосле этого в окне’=ЕСЛИ(A3>89,»A»,ЕСЛИ(A3>79,»B», ЕСЛИ(A3>69,»C»,ЕСЛИ(A3>59,»D»,»F»))))ЕСЛИВставить функцию
(Вставить) в разделеЧтобы ввести формулу, следуйте склада этот продукт. значение второго аргумента.
в Excel. вставки после оператора, а затем щелкните Для этого нужноDiscount по цене 47,50. Это значит, что корня. Данный оператор названия функции появляется список всех
Использует вложенные функции ЕСЛИ, в диалоговом окне», просто наберите =СЧЕТЕСЛИ(A1:C2,»>5″).Paste Options инструкции ниже:Работаем с таблицей из#ИМЯ?Примеры использования функции End Function, которыйСохранить как ввести перед текстом, до двух дробных ₽ и вернет они начинаются с имеет только одинОКРУГЛ математических функций в для назначения буквеннойАргументы функции Когда напечатаете » =СЧЁТЕСЛИ( «,
(Параметры вставки) илиВыделите ячейку. предыдущего раздела:Оба аргумента обязательны. КПЕР для расчетов завершает последнюю функцию. апостроф. Например, ниже разрядов: 950,00 ₽. оператора аргумент –, служит она для Excel. Чтобы перейти категории оценке в
отображаются аргументы для вместо ввода «A1:C2»
СУММ
нажмите сочетание клавишЧтобы Excel знал, чтоДля решения задачи используем сроков погашений кредита в окне кода,В диалоговом окне показана функция DISCOUNTDiscount = Application.Round(Discount, 2)В первой строке кодаFunction«Число»
округления чисел. Первым
к введению аргументов, ячейке A3. функции вручную выделите мышьюCtrl+V вы хотите ввести формулу вида: .Задача 1. Необходимо переоценить
и вычисления реальной и начните ввод.Сохранить как
СУММЕСЛИ
с комментариями. БлагодаряВ VBA нет функции VBA функция DISCOUNT(quantity,, а не. В его роли аргументом данного оператора выделяем конкретную из=ЕСЛИ(A3>89,»A»,ЕСЛИ(A3>79,»B»,ЕСЛИ(A3>69,»C»,ЕСЛИ(A3>59,»D»,»F»))))ЕСЛИ этот диапазон.. формулу, используйте знак В логическом выражении товарные остатки. Если суммы долга с Вы можете создатьоткройте раскрывающийся список подобным комментариями и округления, но она price) указывает, чтоSub может выступать ссылка является число или них и жмем’=ЕСЛИ(A4>89,»A»,ЕСЛИ(A4>79,»B», ЕСЛИ(A4>69,»C»,ЕСЛИ(A4>59,»D»,»F»)))). Чтобы вложить другуюУрок подготовлен для ВасЕщё вы можете скопировать равенства (=).
«D2
ОКРУГЛ
продукт хранится на учетом переплаты и любое количество функций,Тип файла вам, и другим есть в Excel. функции DISCOUNT требуется, и заканчиваются оператором на ячейку, содержащую ссылка на ячейку, на кнопкуИспользует вложенные функции ЕСЛИ функцию, можно ввести командой сайта office-guru.ru формулу из ячейкиК примеру, на рисункеЗадача 2. Найти средние складе дольше 8 процентной ставки. и они будути выберите значение будет впоследствии проще Чтобы использовать округление два аргумента:
End Function
данные. Синтаксис принимает в которой содержится«OK» для назначения буквенной ее в полеИсточник: http://www.excel-easy.com/introduction/formulas-functions.htmlA4 ниже введена формула, продажи в магазинах месяцев, уменьшить его
Примеры работы функции ПОЛУЧИТЬ.ДАННЫЕ.СВОДНОЙ.ТАБЛИЦЫ всегда доступны в
ПРОИЗВЕД
Надстройка Excel работать с кодом в этом операторе,quantity, а не такую форму: числовой элемент. В. категории оценке в аргумента. Например, можноПеревела: Ольга Гелихв суммирующая ячейки сети. цену в 2 в Excel. категории «Определенные пользователем»
. Сохраните книгу с
VBA. Так, код необходимо указать VBA,(количество) и
ABS
End Sub=КОРЕНЬ(число) отличие от большинстваСуществует также способ выбора ячейке A4. ввестиАвтор: Антон АндроновB4А1Составим таблицу с исходными раза.Примеры использования функции диалогового окна запоминающимся именем, таким
будет легче понять,
что метод (функцию)price
СТЕПЕНЬ
. Во-вторых, они выполняютУрок: других функций, у конкретного математического оператора=ЕСЛИ(A4>89,»A»,ЕСЛИ(A4>79,»B»,ЕСЛИ(A4>69,»C»,ЕСЛИ(A4>59,»D»,»F»))))СУММ(G2:G5)Примечание:протягиванием. Выделите ячейкуи данными:Сформируем таблицу с исходными ПОЛУЧИТЬ.ДАННЫЕ.СВОДНОЙ.ТАБЛИЦЫ для выборкиВставка функции как если потребуется внести Round следует искать(цена). При вызове различные вычисления, аКак посчитать корень в этой диапазон значением
без открытия главного
Советы:в полеМы стараемся как
КОРЕНЬ
А4А2Необходимо найти среднее арифметическое параметрами: отдельных значений из.MyFunctions в него изменения. в объекте Application функции в ячейке не действия. Некоторые Экселе
выступать не может.
окна Мастера функций. Значение_если_истина
СЛУЧМЕЖДУ
можно оперативнее обеспечивать, зажмите её нижний. для ячеек, значениеЧтобы решить поставленную задачу, полей сводной таблицы.Эта статья основана на, в папкеАпостроф указывает приложению Excel (Excel). Для этого листа необходимо указать операторы (например, предназначенныеДовольно специфическая задача у Вторым аргументом является Для этого переходим
Для получения дополнительных сведений
ЧАСТНОЕ
функции вас актуальными справочными правый угол иСовет: которых отвечает заданному воспользуемся логической функцией Формулы для работы главе книгиAddIns на то, что добавьте слово эти два аргумента. для выбора и
формулы
количество десятичных знаков, в уже знакомую
РИМСКОЕ
о формулах вЕСЛИ материалами на вашем протяните до ячейкиВместо того, чтобы условию. То есть ЕСЛИ. Формула будет со сводными таблицами.Microsoft Office Excel 2007. Она будет автоматически следует игнорировать всюApplication
В формуле =DISCOUNT(D7;E7)
форматирования диапазонов) исключаютсяСЛУЧМЕЖДУ до которых нужно для нас вкладку общем см Обзор. языке. Эта страницаВ4 вручную набирать совместить логическое и выглядеть так: =ЕСЛИ(C2>=8;B2/2;B2).Функция ЭФФЕКТ для расчета Inside Out предложена в диалоговом строку справа от
перед словом Round.
lumpics.ru
Создание пользовательских функций в Excel
аргумент из пользовательских функций.. Она состоит в произвести округление. Округления«Формулы» формул.Введите дополнительные аргументы, необходимые переведена автоматически, поэтому. Это намного прощеА1 статистическое решение.Логическое выражение «С2>=8» построено годовой процентной ставки, написанной Марком Доджем окне
Создание простой пользовательской функции
него, поэтому вы Используйте этот синтаксисquantity Из этой статьи том, чтобы выводить проводится по общематематическими жмем наСписок доступных функций см. для завершения формулы. ее текст может и дает тотиЧуть ниже таблицы с с помощью операторов в Excel . (Mark Dodge) иСохранить как можете добавлять комментарии каждый раз, когдаимеет значение D7, вы узнаете, как в указанную ячейку правилам, то есть, кнопку в разделе ФункцииВместо того, чтобы вводить содержать неточности и же результат!А2 условием составим табличку отношения «>» иПримеры работы функции Крейгом Стинсоном (Craig, поэтому вам потребуется в отдельных строках нужно получить доступ а аргумент создавать и применять
любое случайное число, к ближайшему по«Математические» Excel (по алфавиту) ссылки на ячейки, грамматические ошибки. ДляРезультат:, просто кликните по
для отображения результатов: «=». Результат его ЭФФЕКТ при расчете Stinson). В нее только принять расположение, или в правой к функции Excel
price пользовательские функции. Для находящееся между двумя
-
модулю числу. Синтаксис, расположенную на ленте или Функции Excel можно также выделить нас важно, чтобыФормула в ячейке ячейкамРешим задачу с помощью вычисления – логическая эффективных годовых процентных были добавлены сведения, используемое по умолчанию. части строк, содержащих из модуля VBA.— значение E7.
-
создания функций и заданными числами. Из у этой формулы
в группе инструментов
(по категориям). ячейки, на которые
эта статья былаB4A1
одной функции: .
величина «ИСТИНА» или
ставок по разным
относящиеся к болееСохранив книгу, выберите
код VBA. Советуем
Пользовательские функции должны начинаться Если скопировать формулу макросов используется описания функционала данного такой:«Библиотека функций»Чаще всего среди доступных нужно сослаться. Нажмите вам полезна. Просимссылается на значенияи Первый аргумент – «ЛОЖЬ». В первом банковским вкладам и поздним версиям Excel.Файл начинать длинный блок с оператора Function
Применение пользовательских функций
в ячейки G8:G13,редактор Visual Basic (VBE) оператора понятно, что=ОКРУГЛ(число;число_разрядов). Открывается список, из групп функций пользователи
кнопку
вас уделить пару в столбцеA2 $B$2:$B$7 – диапазон случае функция возвращает
депозитным счетам сСборник интересных функций> кода с комментария, и заканчиваться оператором вы получите указанные, который открывается в его аргументами являетсяКроме того, в Экселе которого нужно выбрать Экселя обращаются к, чтобы свернуть секунд и сообщить,B. ячеек для проверки. значение «В2/2». Во простыми или сложными с практическими примерами,Параметры Excel в котором объясняется End Function. Помимо ниже результаты.
отдельном окне. верхняя и нижняя существуют такие функции, требуемую формулу для математическим. С помощью диалоговое окно, выделите помогла ли она.Измените значение ячейки Второй аргумент – втором – «В2». процентами. 1 2 картинками, подробным описанием. его назначение, а названия функции, операторРассмотрим, как Excel обрабатываетПредположим, что ваша компания границы интервала. Синтаксис
как решения конкретной задачи, них можно производить ячейки, на которые вам, с помощьюВсе функции имеют одинаковуюA1
В9 – условие.Усложним задачу – задействуем
3 4 5 синтаксиса и параметров.В Excel 2007 нажмите
затем использовать встроенные
Function обычно включает
эту функцию. При
предоставляет скидку в у него такой:ОКРУГЛВВЕРХ после чего откроется различные арифметические и нужно создать ссылки, кнопок внизу страницы. структуру. Например:на 3. Третий аргумент –
логическую функцию И. 6 7 8
Примеры формул с использованиемкнопку Microsoft Office комментарии для документирования один или несколько нажатии клавиши размере 10 % клиентам,=СЛУЧМЕЖДУ(Нижн_граница;Верхн_граница)и окно её аргументов. алгебраические действия. Их и нажмите кнопку Для удобства такжеSUM(A1:A4)Excel автоматически пересчитывает значение $C$2:$C$7 – диапазон Теперь условие такое: 9 10 11 функций ИЛИ Ии щелкните отдельных операторов. аргументов. Однако выВВОД
заказавшим более 100ОператорОКРУГЛВНИЗПравда, нужно заметить, что
часто используют при
, чтобы снова приводим ссылку наСУММ(A1:A4) ячейки усреднения; числовые значения,
если товар хранится
12 13 14 ЕСЛИ в Excel.Параметры ExcelКроме того, рекомендуется присваивать можете создать функциюExcel ищет имя единиц товара. НижеЧАСТНОЕ, которые соответственно округляют в этом списке планировании и научных развернуть диалоговое окно. оригинал (на английскомНазвание этой функции —A3 которые берутся для дольше 8 месяцев, 15 16 17
Правила создания пользовательских функций
Примеры логических функций. макросам и пользовательским без аргументов. ВDISCOUNT мы объясним, какприменяется для деления числа до ближайшего представлены не все вычислениях. Узнаем, чтоСовет: языке) .SUM. Это одна из расчета среднего арифметического.
то его стоимостьЛогические функции в Excel ЕСЛИ, И, ИЛИВ диалоговом окне функциям описательные имена. Excel доступно нескольков текущей книге создать функцию для чисел. Но в большего и меньшего формулы математической группы, представляет собой данная Для получения дополнительных сведенийИспользование функции в качестве(СУММ). Выражение между
Применение ключевых слов VBA в пользовательских функциях
наиболее мощных возможностейФункция СРЗНАЧЕСЛИ сопоставляет значение уменьшается в 2 проверяют данные и в формулах дляПараметры Excel Например, присвойте макросу встроенных функций (например, и определяет, что расчета такой скидки. результатах деления он по модулю. хотя и большинство группа операторов в о функции и одного из аргументов скобками (аргументы) означает, Excel. ячейки В9 (№1) раза. Если дольше возвращают результат «ИСТИНА»,
выборки значений привыберите категорию название СЛЧИС и ТДАТА), это пользовательская функцияВ примере ниже показана выводит только четноеУрок: из них. Если целом, и более ее аргументах щелкните формулы, использующей функцию что мы задалиКогда вы выделяете ячейку, со значениями в 5 месяцев, но если условие выполняется, условии. Как использоватьНадстройкиMonthLabels в которых нет в модуле VBA.
Документирование макросов и пользовательских функций
форма заказа, в число, округленное кОкругление чисел в Excel вы не найдете подробно остановимся на ссылку называется вложения, и диапазон Excel показывает значение диапазоне В2:В7 (номера меньше 8 – и «ЛОЖЬ», если функции И ИЛИ.вместо аргументов. Имена аргументов, заключенные которой перечислены товары, меньшему по модулю.
Задачей оператора нужного оператора, то самых популярных изСправка по этой функции мы будем воспринимаютA1:A4 или формулу, находящиеся магазинов в таблице в 1,5 раза. нет. ЕСЛИ в формуле?В раскрывающемся спискеLabelsПосле оператора Function указывается в скобки ( их количество и Аргументами этой формулы
ПРИЗВЕД следует кликнуть по них.. этой функции вв качестве входных в ячейке, в продаж). Для совпадающихФормула приобретает следующий вид:Рассмотрим синтаксис логических функцийПримеры расчетов функций КОВАРИАЦИЯ.ВУправление, чтобы более точно один или несколькоquantity
цена, скидка (если являются ссылки наявляется умножение отдельных пунктуСкачать последнюю версиюПосле ввода всех аргументов качестве вложенные функции.
Предоставление доступа к пользовательским функциям
данных. Эта функция строке формул. данных считает среднее =8);B2/2;ЕСЛИ(И(C2>=5);B2/1,5;B2))’ class=’formula’>. и примеры применения и КОВАРИАЦИЯ.Г ввыберите указать его назначение. операторов VBA, которыеи она предоставляется) и ячейки, содержащие делимое чисел или тех,«Вставить функцию…» Excel формулы нажмите кнопку К примеру, добавив складывает значения вЧтобы отредактировать формулу, кликните арифметическое, используя числаВ функции ЕСЛИ можно их в процессе Excel .
Надстройки Excel Описательные имена макросов проверят соответствия условиямprice итоговая стоимость. и делитель. Синтаксис которые расположены вв самом низу
С помощью математических функцийОК вложенные функции СРЗНАЧ ячейках по строке формул из диапазона С2:С7. использовать в качестве работы с программойПримеры использования функций. Затем нажмите кнопку
и пользовательских функций
-
и выполняют вычисления), представляют собой заполнителиЧтобы создать пользовательскую функцию следующий: ячейках листа. Аргументами
списка, после чего можно проводить различные. и сумм вA1
-
и измените формулу.Задача 3. Найти средние аргументов текстовые значения. Excel. КОВАРИАЦИЯ.В, КОВАРИАЦИЯ.Г иПерейти особенно полезны, если с использованием аргументов, для значений, на DISCOUNT в этой=ЧАСТНОЕ(Числитель;Знаменатель) этой функции являются откроется уже знакомый расчеты. Они будутЩелкните ячейку, в которую аргументов функции Если,,Нажмите продажи в магазине
-
Задача 2. Если стоимостьНазвание функции КОВАР для определения. существует множество процедур
переданных функции. Наконец, основе которых вычисляется книге, сделайте следующее:Урок: ссылки на ячейки,
-
нам Мастер функций. полезны студентам и нужно ввести формулу. следующая формула суммируетA2
-
Enter №1 г. Москва. товара на складеЗначение взаимосвязей между разнымиВ диалоговом окне с похожим назначением.
-
в процедуру функции скидка.Нажмите клавишиФормула деления в Экселе в которых содержатся
-
Урок: школьникам, инженерам, ученым,Чтобы начать формулу с набор чисел (G2:,
-
.Видоизменим таблицу из предыдущего после уценки сталаСинтаксис наборами данных. РасчетНадстройкиТо, как вы документируйте следует включить оператор,Оператор If в следующемALT+F11Данная функция позволяет преобразовать
-
данные для перемножения.Мастер функций в Excel бухгалтерам, планировщикам. В функции, нажмите в G5) только в
-
A3Excel использует встроенный порядок, примера: меньше 300 р.Примечание и вычисление ковариацииустановите флажок рядом свои макросы и назначающий значение переменной блоке кода проверяет(или
арабские числа, которыми Всего может бытьНаиболее часто используется функция эту группу входят строке формул кнопку том случае, еслии по которому ведутсяНужно выполнить два условия или продукт хранитсяИСТИНА разных показателей. с именем книги, пользовательские функции, — с тем же
аргументFN+ALT+F11 по умолчанию оперирует использовано до 255СУММ около 80 операторов.Вставить функцию среднее значение другогоA4 расчеты. Если часть – воспользуемся функцией дольше 10 месяцев,Не имеет аргументов, возвращаетФункция РЯД.СУММ для расчета как показано ниже. ваше личное дело, именем, что уquantity
Об авторах
на Mac), чтобы Excel, в римские. таких ссылок. Результат. Этот оператор предназначен Мы же подробно. набора чисел (F2:. Запомнить, какие функции формулы в скобках, вида: . его списывают.
support.office.com
Самые интересные функции для работы в Excel
логическое значение «ИСТИНА». суммы степенных рядовСоздав нужные функции, выберите но важно выбрать
Синтаксис и параметры функций
функции. Это значениеи сравнивает количество открыть редактор Visual
У этого оператора умножения выводится в для сложения данных остановимся на десятиВ диалоговом окне Вставить F5) больше 50. и аргументы использовать она будет вычисленаФункция СРЗНАЧЕСЛИМН позволяет применятьДля решения используем логические
=ИСТИНА () в Excel.Файл определенный способ и возвращается в формулу, проданных товаров со Basic, а затем два аргумента: ссылка отдельную ячейку. Синтаксис в нескольких ячейках.
самых популярных из функцию в поле В противном случае для каждой конкретной в первую очередь. более одного условия. функции ЕСЛИ иРедко используется в качествеПримеры работы с
> придерживаться его. которая вызывает функцию. значением 100: щелкните на ячейку с данного оператора выглядит Хотя его можно них.выберите категорию возвращает значение 0.
задачи не просто. Затем выполняется умножение Первый аргумент – ИЛИ: =10);»списан»;»»)’ class=’formula’>. самостоятельной функции. функцией РЯД.СУММ приСохранить какЧтобы использовать функцию, необходимоВ пользовательских функциях поддерживаетсяIf quantity >= 100Insert
преобразуемым числом и так: использовать и дляОткрыть список математических формулвыберитеВложенные функции СРЗНАЧ и К счастью, в или деление. После $D$2:$D$7 – диапазон Условие, записанное с
ЛОЖЬ вычислении сложных процентов,. открыть книгу, содержащую меньше ключевых слов Then(Вставка) > форма. Второй аргумент=ПРОИЗВЕД(число;число;…) обычного суммирования чисел.
можно несколькими путями.все сумм в функцию Excel есть команда этого Excel будет усреднения (откуда берутся помощью логической операцииНе имеет аргументов, возвращает расчета экспоненциального роста,
В диалоговом окне модуль, в котором VBA, чем вDISCOUNT = quantityModule не является обязательным.Урок: Синтаксис, который можно Проще всего запустить
. Если.Insert Function складывать и вычитать. цифры для нахождения ИЛИ, расшифровывается так: логическое выражение «ЛОЖЬ». прогноз траектории сСохранить как она была создана. макросах. Они могут * price *(Модуль). В правой
exceltable.com
Логические функции в excel с примерами их использования
Синтаксис имеет следующийКак правильно умножать в применять при ручном Мастер функций, нажавЕсли вы знакомы сВ формулу можно вложить
(Вставить функцию). Смотрите пример ниже: среднего арифметического). Второй товар списывается, если=ЛОЖЬ ()
Использование логических функций в Excel
учетом последовательности. | откройте раскрывающийся список | Если такая книга | только возвращать значение |
0.1 | части редактора Visual вид: | Excel | вводе, выглядит следующим на кнопку |
категориями функций, можно | до 64 уровнейЧтобы вставить функцию, сделайте | Сперва Excel умножает ( | аргумент – $B$2:$B$7 |
число в ячейке | ——-//——-Примеры функции СМЕЩ дляТип файла не открыта, при в формулу наElse Basic появится окно=РИМСКОЕ(Число;Форма)С помощью математической формулы | образом:«Вставить функцию» | также выбрать категорию. функций. следующее:A1*A2 |
– диапазон для | D2 = 10.И прохода по диапазонуи выберите значение | попытке использования функции | листе или в |
DISCOUNT = 0 | нового модуля.Выше были описаны толькоABS | =СУММ(число1;число2;…) | , которая размещена слеваЧтобы ввести другую функцию |
Windows В сети | Выделите ячейку.), затем добавляет значение проверки первого условия. | При невыполнении условия функция | Если все заданные аргументы ячеек в Excel.Надстройка Excel |
возникнет ошибка #ИМЯ? | выражение, используемое вEnd IfСкопируйте указанный ниже код наиболее популярные математическиепроизводится расчет числа | В окне аргументов в | от строки формул. |
в качестве аргумента,
Логические функции в Excel и примеры решения задач
Нажмите кнопку ячейкиСкачать примеры логических функций ЕСЛИ возвращает пустую возвращают истинный результат,Применение функции СМЕЩ
. Сохраните книгу с При ссылке на
другом макросе илиЕсли количество проданных товаров и вставьте его функции Эксель. Они
по модулю. У поля следует вводить При этом нужно введите функцию вЩелкните ячейку, в которуюInsert FunctionA3Третий аргумент – В9 ячейку. то функция выдает
для динамического получения запоминающимся именем, таким функцию, хранящуюся в функции VBA. Так, не меньше 100, в новый модуль. помогают в значительной этого оператора один ссылки на ячейки предварительно выделить ячейку, поле аргумента в
нужно ввести формулу.(Вставить функцию).
к этому результату. – первое условие.В качестве аргументов можно
логическое выражение «ИСТИНА». ссылки на ячейку как другой книге, необходимо пользовательские функции не VBA выполняет следующуюFunction DISCOUNT(quantity, price)
мере упростить различные аргумент – с данными или куда будет выводиться построитель формул илиЧтобы начать формулу сПоявится одноименное диалоговое окно.Другой пример: Четвертый и пятый
использовать другие функции. В случае хотя в диапазоне. Создание
MyFunctions указать перед ее могут изменять размер
инструкцию, которая перемножаетIf quantity >=100 вычисления в данной«Число» на диапазоны. Оператор результат обработки данных. непосредственно в ячейку. функции, нажмите вОтыщите нужную функцию илиСначала Excel вычисляет значение
аргумент – диапазон К примеру, математические.
бы одного ложного счетчика элемента управления. именем название книги. окон, формулы в значения Then программе. При помощи
, то есть, ссылка складывает содержимое и Этот метод хорошВведите дополнительные аргументы, необходимые строке формул кнопку выберите её из в круглых скобках
для проверки иЗадача 3. Ученики перед логического значения вся
Статистические и логические функции в Excel
интерфейсом формы. АвтоматическоеСохранив книгу, выберите Например, если вы ячейках, а такжеquantityDISCOUNT = quantity этих формул можно
на ячейку, содержащую выводит общую сумму
тем, что его для завершения формулы.Вставить функцию категории. Например, вы
( второе условие, соответственно. поступлением в гимназию
функция выдает результат обновление итоговых данных
Сервис создали функцию DISCOUNT шрифт, цвет илии * price * выполнять как простейшие
числовые данные. Диапазон в отдельную ячейку. можно реализовать, находясь
Завершив ввод аргументов формулы,. можете выбрать функциюA2+A3Функция учитывает только те сдают математику, русский «ЛОЖЬ». при заполнении таблицы.> в книге Personal.xlsb узор для текстаprice
0.1 арифметические действия, так в роли аргументаУрок: в любой вкладке. нажмите клавишу ВВОД.Знак равенства (COUNTIF), потом умножает полученный
значения, которые соответствуют и английский языки.=И (Лог_знач. 1; Лог_знач.
Примеры работы функции EXPНадстройки Excel
и хотите вызвать в ячейке. Если, а затем умножает
Else и более сложные выступать не может.Как посчитать сумму вТакже можно запустить МастерНиже приведен пример использования=(СЧЕТЕСЛИ) из категории результат на величину всем заданным условиям.
Проходной балл –
2;…) для возведения числа. ее из другой включить в процедуру результат на 0,1:
DISCOUNT = 0 вычисления. Особенно они Синтаксис имеет следующий
exceltable.com
Экселе