Функции Excel.Функция И(), ИЛИ(). Мастер функций в программе Microsoft Excel

Для чего нужны функции в C?

Функции в Си применяются для выполнения определённых действий в рамках общей программы. Программист сам решает какие именно действия вывести в функции. Особенно удобно применять функции для многократно повторяющихся действий.

Простой пример функции в Cи

Пример функции в Cи:

#include #include int main(void) { puts("Functions in C"); return EXIT_SUCCESS; }

Это очень простая программа на Си. Она просто выводит строку «Functions in C». В программе имеется единственная функция под названием main. Рассмотрим эту функцию подробно. В заголовке функции, т.е. в строке

int – это тип возвращаемого функцией значения;

main - это имя функции;

(void) - это перечень аргументов функции. Слово void указывает, что у данной функции нет аргументов;

return – это оператор, который завершает выполнение функции и возвращает результат работы функции в точку вызова этой функции;

EXIT_SUCCESS - это значение, равное нулю. Оно определено в файле stdlib.h;

часть функции после заголовка, заключенная в фигурные скобки

{
puts("Functions in C");
return EXIT_SUCCESS;
}

называют телом функции.

Итак, когда мы работаем с функцией надо указать имя функции, у нас это main, тип возвращаемого функцией значения, у нас это int, дать перечень аргументов в круглых скобках после имени функции, у нас нет аргументов, поэтому пишем void, в теле функции выполнить какие-то действия (ради них и создавалась функция) и вернуть результат работы функции оператором return. Вот основное, что нужно знать про функции в C.

Как из одной функции в Cи вызвать другую функцию?

Рассмотрим пример вызова функций в Си:

/* Author: @author Subbotin B.P..h> #include int main(void) { puts("Functions in C"); int d = 1; int e = 2; int f = sum(d, e); printf("1 + 2 = %d", f); return EXIT_SUCCESS; }

Запускаем на выполнение и получаем:

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

Заголовок функции sum:

int sum(int a, int b)

здесь int - это тип возвращаемого функцией значения;

sum - это имя функции;

(int a, int b) - в круглых скобках после имени функции дан перечень её аргументов: первый аргумент int a, второй аргумент int b. Имена аргументов являются формальными, т.е. при вызове функции мы не обязаны отправлять в эту функцию в качестве аргументов значения перемнных с именами a и b. В функции main мы вызываем функцию sum так: sum(d, e);. Но важно, чтоб переданные в функцию аргументы совпадали по типу с объявленными в функции.

В теле функции sum, т.е. внутри фигурных скобок после заголовка функции, мы создаем локальную переменную int c, присваиваем ей значение суммы a плюс b и возвращаем её в качестве результата работы функции опрератором return.

Теперь посмотрим как функция sum вызывается из функции main.

Вот функция main:

Int main(void) { puts("Functions in C"); int d = 1; int e = 2; int f = sum(d, e); printf("1 + 2 = %d", f); return EXIT_SUCCESS; }

Сначала мы создаём две переменных типа int

Int d = 1; int e = 2;

их мы передадим в функцию sum в качестве значений аргументов.

int f = sum(d, e);

её значением будет результат работы функции sum, т.е. мы вызываем функцию sum, которая возвратит значение типа int, его-то мы и присваиваем переменной f. В качестве аргументов передаём d и f. Но в заголовке функции sum

int sum(int a, int b)

аргументы называются a и b, почему тогда мы передаем d и f? Потому что в заголовке функций пишут формальные аргументы, т.е. НЕ важны названия аргументов, а важны их типы. У функции sum оба аргумента имеют тип int, значит при вызове этой функции надо передать два аргумента типа int с любыми названиями.

Ещё одна тонкость. Функция должна быть объявлена до места её первого вызова. В нашем примере так и было: сначала объявлена функция sum, а уж после мы вызываем её из функции main. Если функция объявляется после места её вызова, то следует использовать прототип функции.

Прототип функции в Си

Рассмотрим пример функциив Си:

/* Author: @author Subbotin B.P..h> #include int sum(int a, int b); int main(void) { puts("Functions in C"); int d = 1; int e = 2; int f = sum(d, e); printf("1 + 2 = %d", f); return EXIT_SUCCESS; } int sum(int a, int b) { int c = 0; c = a + b; return c; }

В этом примере функция sum определена ниже места её вызова в функции main. В таком случае надо использовать прототип функции sum. Прототип у нас объявлен выше функции main:

int sum(int a, int b);

Прототип - это заголовок функции, который завершается точкой с запятой. Прототип - это объявление функции, которая будет ниже определена. Именно так у нас и сделано: мы объявили прототип функции

int f = sum(d, e);

а ниже функции main определяем функцию sum, которая предварительно была объявлена в прототипе:

Int sum(int a, int b) { int c = 0; c = a + b; return c; }

Чем объявление функции в Си отличается от определения функции в Си?

Когда мы пишем прототип функции, например так:

int sum(int a, int b);

то мы объявляем функцию.

А когда мы реализуем функцию, т.е. записываем не только заголовок, но и тело функции, например:

Int sum(int a, int b) { int c = 0; c = a + b; return c; }

то мы определяем функцию.

Оператор return

Оператор return завершает работу функции в C и возвращает результат её работы в точку вызова. Пример:

Int sum(int a, int b) { int c = 0; c = a + b; return c; }

Эту функцию можно упростить:

Int sum(int a, int b) { return a + b; }

здесь оператор return вернёт значение суммы a + b.

Операторов return в одной функции может быть несколько. Пример:

Int sum(int a, int b) { if(a > 2) { return 0;// Первый случай; } if(b < 0) { return 0;// Второй случай; } return a + b; }

Если в примере значение аргумента a окажется больше двух, то функция вернет ноль (первый случай) и всё, что ниже комментария «// Первый случай;» выполнятся не будет. Если a будет меньше двух, но b будет меньше нуля, то функция завершит свою работу и всё, что ниже комментария «// Второй случай;» выполнятся не будет.

И только если оба предыдущих условия не выполняются, то выполнение программы дойдёт до последнего оператора return и будет возвращена сумма a + b.

Передача аргументов функции по значению

Аргументы можно передавать в функцию C по значению. Пример:

/* Author: @author Subbotin B.P..h> #include int sum(int a) { return a += 5; } int main(void) { puts("Functions in C"); int d = 10; printf("sum = %d\n", sum(d)); printf("d = %d", d); return EXIT_SUCCESS; }

В примере, в функции main, создаём переменную int d = 10. Передаём по значению эту переменную в функцию sum(d). Внутри функции sum значение переменной увеличивается на 5. Но в функции main значение d не изменится, ведь она была передана по значению. Это означает, что было передано значение переменной, а не сама переменная. Об этом говорит и результат работы программы:

т.е. после возврата из функции sum значеие d не изменилось, тогда как внутри функции sum оно менялось.

Передача указателей функции Си

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

/* Author: @author Subbotin B.P..h> #include int sum(int *a) { return *a += 5; } int main(void) { puts("Functions in C"); int d = 10; printf("sum = %d\n", sum(&d)); printf("d = %d", d); return EXIT_SUCCESS; }

В этом варианте программы я перешел от передачи аргумента по значению к передаче указателя на переменную. Рассмотрим подробнее этот момент.

printf("sum = %d\n", sum(&d));

в функцию sum передается не значение переменной d, равное 10-ти, а адрес этой переменной, вот так:

Теперь посмотрим на функцию sum:

Int sum(int *a) { return *a += 5; }

Аргументом её является указатель на int. Мы знаем, что указатель - это переменная, значением которой является адрес какого-то объекта. Адрес переменной d отправляем в функцию sum:

Внутри sum указатель int *a разыменовывается. Это позволяет от указателя перейти к самой переменной, на которую и указывает наш указатель. А в нашем случае это переменная d, т.е. выражение

равносильно выражению

Результат: функция sum изменяет значение переменной d:

На этот раз изменяется значение d после возврата из sum, чего не наблюдалось в предыдущм пункте, когда мы передавали аргумент по значению.

C/C++ в Eclipse

Все примеры для этой статьи я сделал в Eclipse. Как работать с C/C++ в Eclipse можно посмотреть . Если вы работаете в другой среде, то примеры и там будут работать.

" была рассмотрена работа со встроенной функцией ЕСЛИ(). Все бы хорошо, но возникают такие ситуации, и довольно часто, когда вложенностью условия в условие не обойтись. Например, элементарно необходимо проверить следующее: 1 больше или равно x и x меньше или равно 5 . Реализовать такое условие несколькими ЕСЛИ довольно громоздко и проблематично, а в некоторых ситуациях - вообще невозможно. Для расширения функционала ЕСЛИ и облегчения составления формул с условием, в Excel имеются еще пара полезных функции - И() и ИЛИ().

Функция И()

Функция И() Условие 1 И Условие 2 . При этом все условия должны быть истинными. Результатом работы данной функции является ИСТИНА или ЛОЖЬ (TRUE / FALSE). Пример: ЕСЛИ а = b И а=с ТОГДА значение 1 ИНАЧЕ значение 2.
Как видно из примера, значение 1 будет только в том случае, если все условия верны.

Функция ИЛИ()

Функция ИЛИ() используется тогда, когда необходимо проверить несколько условий следующим образом - Условие 1 ИЛИ Условие 2 . Результат функции будет истинным, если хотя бы одно из условий истинно. Пример: ЕСЛИ а = b ИЛИ а=с ТОГДА значение 1 ИНАЧЕ значение 2.

Синтаксис функций И() и ИЛИ() одинаков: Функция(Условие 1; Условие 2; Условие 3 и до 30-ти условий). Результат ИСТИНА или ЛОЖЬ.

Примеры использования функции И и ИЛИ

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

Пример 1.
Столбец А, начиная с первой строки, содержит 56, 55, 88, 6, 74. Столбец В - 52, 55, 88, 4, 25. Столбец С - 53, 55, 88, 6, 25. С помощью функций ЕСЛИ и И необходимо определить строки, значения которых равны следующим образом А=В и В=С.

Переходим в ячейку D1 и с помощью мастера функций вводим следующее

Формула будет выглядеть так: “ =ЕСЛИ(И(A1=B1;B1=C1);"Все значения равны";"Значения не равны") “

Результат работы:

Пример 2.

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

Мастер функций выглядит так:

Формула: “ =ЕСЛИ(ИЛИ(A1=B1;B1=C1;A1=C1);"Есть равные значения";"Нет равных значений")”

Результат:

Вот и все. Функции не сложны. Применяйте их там, где встречаются условия и произносится И и ИЛИ. Так же, всеми выше перечисленными функциями можно сравнивать текстовые значения.

И напоследок рассмотрим еще один пример с функцией И и ИЛИ из реальной жизни.

Пример 3.

В таблицу занесены процент выполнения заданий, необходимо проценты перевести в пятибалльную систему следующим образом:

1 – от 0% до 10%
2- от 11% до 30%
3- от 31% до 40%
4- от 41% до 75%
5-от 76% до 100%

Таблица следующего вида.

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

  • таблица должна обязательно содержать заголовки столбцов. Эти заголовки должны располагаться строго в одной строке, не должны содержать объединенных и пустых ячеек.
  • таблица должна быть неделимая, т.е. не должна содержать полностью пустых строк и столбцов, а так же объединенных ячеек
  • в каждом столбце должна содержаться однотипная информация: если в столбце должны содержаться даты, значит кроме дат там не должно быть ничего другого; если в столбце числа(суммы, кол-во) - значит должны быть только числа. Не следует при отсутствии чисел оставлять ячейку пустой или ставить пробел. Вместо этого необходимо ставить 0.

Для разбора функции баз данных возьмем следующий пример таблицы:

Данная таблица отвечает всем требованиям для работы с функциями баз данных, однако, чтобы более удобно и гибко работать с функциями баз данных лучше сместить таблицу данных на несколько строк вниз, а выше добавить таблицу критериев, где будут формироваться условия отбора данных из основной таблицы:


Именно для этой таблицы будут приведены все примеры описаний функций. И критерии заданы следующие: отбирать из поля "Дерево" Яблони с высотой больше 3 и меньше 6 и Вишни, со значением в поле "Возраст" больше 8. Если посмотреть на таблицу данных(из которой будут отбираться данные и производится расчеты функциями), то этим критериям отвечают только две строки: строки 9 и 10 листа.
Как видно, в качестве критериев можно указывать выражение в виде: >6 , 0 (не равно нулю), >=7 , "Яблоня" .

Все функции из категории баз данных имеют три одинаковых аргумента:
Функция(база_данных; поле; критерий)
база_данных - ссылка на ячейки данных таблицы, включая заголовок(A6:E12).
поле - в данном аргументе можно записать как непосредственно текст с названием столбца в кавычках ("Дерево", "Возраст" или "Урожай"), так и число, задающее положение столбца в таблице: 1 - для первого поля(столбца) в таблице "Дерево", 2 - для второго поля "Высота", 3 - для третьего поля "Возраст" и так далее.
критерий - ссылка на диапазон ячеек с условиями отбора(A1:F3). Функция отберет данные из таблицы, которые удовлетворяют условиям, указанным в ячейках критериев. В ссылке на критерии обязательно должны быть включены названия столбцов, для которых выполняется отбор данных.

  • ДСРЗНАЧ (DAVERAGE) - Вычисляет среднее значение выбранных записей базы данных:
    =ДСРЗНАЧ(A6:E12 ;5; A1:F3)
    =ДСРЗНАЧ(A6:E12 ;"Прибыль"; A1:F3)
    =DAVERAGE(A6:E12 ,5, A1:F3) вернет значение 90 000р. , т.к. сумма прибыли отобранных записей равна 180 000р., а всего отобрано 2 записи. 180 000/2 = 90 000 .
  • БСЧЁТ (DCOUNT) - Подсчитывает количество числовых ячеек в базе данных:
    =БСЧЁТ(A6:E12 ;5; A1:F3)
    =БСЧЁТ(A6:E12 ;"Прибыль"; A1:F3)
    =DCOUNT(A6:E12 ,5, A1:F3) вернет число 2 , т.к. только две строки в таблице отвечают критериям
  • БСЧЁТА (DCOUNTA) - Подсчитывает количество непустых ячеек в базе данных:
    =БСЧЁТА(A6:E12 ;4; A1:F3)
    =БСЧЁТА(A6:E12 ;"Прибыль"; A1:F3)
    =DCOUNTA(A6:E12 ,4, A1:F3) вернет 2, т.е. подсчитает в отвечающих критериям строках количество непустых ячеек в столбце "Прибыль"
  • БИЗВЛЕЧЬ (DGET) - Извлекает из базы данных одну запись, удовлетворяющую заданному условию:
    =БИЗВЛЕЧЬ(A6:E12 ;5; A1:F3)
    =БИЗВЛЕЧЬ(A6:E12 ;"Прибыль"; A1:F3)
    =DGET(A6:E12 ,5, A1:F3) для заданных условий вернет значение ошибки #ЧИСЛО! (#NUM!) , т.к. этим условиям отвечает более одной записи. Если же указать диапазон для критерия как:
    =БИЗВЛЕЧЬ(A6:E12 ;5; A1:F2) то функция вернет значение 75 000р. , т.е. единственную запись о прибыли для Яблонь с высотой больше 3 и меньше 6 (в данный промежуток попадает лишь строка 10 - Яблона, высота 5)
  • ДМАКС (DMAX) - Находит максимальное значение среди выделенных записей базы данных:
    =ДМАКС(A6:E12 ;5; A1:F3)
    =ДМАКС(A6:E12 ;"Прибыль"; A1:F3)
    =DMAX(A6:E12 ,5, A1:F3) вернет сумму 105 000р. , т.к. это максимальная прибыль из всех отвечающих критериям строк.
  • ДМИН (DMIN) - Находит минимальное значение среди выделенных записей базы данных:
    =ДМИН(A6:E12 ;5; A1:F3)
    =ДМИН(A6:E12 ;"Прибыль"; A1:F3)
    =DMIN(A6:E12 ,5, A1:F3) вернет сумму 75 000р. , т.к. это минимальная прибыль из всех строк, отвечающих критериям
  • БДПРОИЗВЕД (DPRODUCT) - Перемножает значения определенного поля в записях базы данных, удовлетворяющих условию:
    =БДПРОИЗВЕД(A6:E12 ;3; A1:F3)
    =БДПРОИЗВЕД(A6:E12 ;"Возраст"; A1:F3)
    =DPRODUCT(A6:E12 ,3, A1:F3) вернет 210 , т.к. будут перемножены все значения столбца "Возраст", отвечающие критериям(14*15=210)
  • ДСТАНДОТКЛ (DSTDEV) - Оценивает стандартное отклонение по выборке из выделенных записей базы данных:
    =ДСТАНДОТКЛ(A6:E12 ;4; A1:F3)
    =ДСТАНДОТКЛ(A6:E12 ;"Урожайность"; A1:F3)
    =DSTDEV(A6:E12 ,4, A1:F3) вернет 0,707107 , т.е. оценку стандартного отклонения урожайности по указанным критериям.
  • ДСТАНДОТКЛП (DSTDEVP) - Вычисляет стандартное отклонение по генеральной совокупности из выделенных записей базы данных:
    =ДСТАНДОТКЛП(A6:E12 ;4; A1:F3)
    =ДСТАНДОТКЛП(A6:E12 ;"Урожайность"; A1:F3)
    =DSTDEVP(A6:E12 ,4, A1:F3) вернет 0,5 , т.е. точное стандартное отклонение урожайности по указанным критериям, если считать, что данные в базе данных описывают генеральную совокупность всех деревьев в саду.
  • БДСУММ (DSUM) - Суммирует числа в поле для записей базы данных, удовлетворяющих условию:
    =БДСУММ(A6:E12 ;5; A1:F3)
    =БДСУММ(A6:E12 ;"Прибыль"; A1:F3)
    =DSUM(A6:E12 ,5, A1:F3) вернет сумму прибыли всех строк, отвечающих критериям, т.е. 180 000р.
    =БДСУММ(A6:E12 ;5; A1:A2)
    =DSUM(A6:E12 ,5, A1:A2) вернет сумму прибыли от всех Яблонь, т.е. 225 000р.
  • БДДИСП (DVAR) - Оценивает дисперсию по выборке из выделенных записей базы данных:
    =БДДИСП(A6:E12 ;4; A1:A2)
    =БДДИСП(A6:E12 ;"Урожайность"; A1:A2)
    =DVAR(A6:E12 ,4, A1:A2) вернет 0,5 , что будет оценкой дисперсии урожайности по указанным критериям, если считать, что данные в таблице являются выборкой из генеральной совокупности всех деревьев в саду
  • БДДИСПП (DVARP) - Вычисляет дисперсию по генеральной совокупности из выделенных записей базы данных:
    =БДДИСПП(A6:E12 ;4; A1:A2)
    =БДДИСПП(A6:E12 ;"Урожайность"; A1:A2)
    =DVARP(A6:E12 ,4, A1:A2) вернет 10,66667 , т.е. точную дисперсию урожайности Яблонь и Вишень, если считать, что данные в базе данных описывают генеральную совокупность всех деревьев в саду

В третьей части материалов «Excel 2010 для начинающих» мы поговорим об алгоритмах копирования формул и системе отслеживания ошибок при их составлении. Помимо этого, вы узнаете, что такое функции, а так же как представлять данные или результаты вычислений в графическом виде с помощью диаграмм и спарклайнов.

Вступление

Во второй части цикла «Excel 2010 для начинающих» мы изучили некоторые возможности форматирования таблицы, например, добавление строк и столбцов, а так же объединение ячеек. Помимо этого вы узнали, как выполнять в Excel арифметические операции и научились составлять простые формулы.

В начале этого материала мы еще немного поговорим о формулах - расскажем, как их редактировать, поговорим о системе оповещения об ошибках и инструментах отслеживания ошибок, а так же узнаем, с помощью каких алгоритмов в Excel осуществляется копирование и перемещение формул. Затем мы познакомимся с еще одним важнейшим понятием в электронных таблицах - функциями. Напоследок, вы узнаете, как в MS Excel 2010 можно представлять данные и полученные результаты в наглядном (графическом) виде, используя диаграммы и спарклайны.

Редактирование формул и система отслеживания ошибок

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

После окончания редактирования нажмите клавиши Enter или Tab, после чего Excel выполнить перерасчет с учетом изменений и отобразит результат.

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

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

Расшифровка ошибок в Excel:

  • ##### - результатом выполнения формулы, использующей значения даты и времени стало отрицательное число или результат обработки не умещается в ячейке;
  • #ЗНАЧ! - используется недопустимый тип оператора или аргумента формулы. Одна из самых распространенных ошибок;
  • #ДЕЛ/0! - в формуле осуществляется попытка деления на ноль;
  • #ИМЯ? - используемое в формуле имя некорректно и Excel не может его распознать;
  • #Н/Д - неопределенные данные. Чаще всего эта ошибка возникает при неправильном определении аргумента функции;
  • #ССЫЛКА! - формула содержит недопустимую ссылку на ячейку, например, на ячейку, которая была удалена.
  • #ЧИСЛО! - результатом вычисления является число, которое слишком мало или слишком велико, что бы его можно было использовать в MS Excel. Диапазон отображаемых чисел лежит в промежутке от -10 307 до 10 307 .
  • #ПУСТО! - в формуле задано пересечение областей, которые на самом деле не имеют общих ячеек.

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

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

Влияющие ячейки - это ячейки, на которые ссылаются формулы, а зависимые ячейки , наоборот, содержат формулы, ссылающиеся на адреса клеток электронной таблицы.

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

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

Не смотря на то, что формула в данной ячейке имеет вид «=H5 - H12», программа Excel, cпомощью стрелок зависимостей, может показать все значения, которые учувствуют в вычислении конечного результата. Ведь в клетках H5 и H12 так же содержаться формулы, имеющие ссылки на другие адреса, которые в свою очередь, могут содержать как формулы, так и числовые константы.

Чтобы удалить все стрелки с рабочего листа, в группе Зависимости формул на вкладке Формулы , нажмите кнопку Убрать стрелки .

Относительные и абсолютные адреса ячеек

Возможность копирования формул в Excel из одной ячейки в другую с автоматическим изменением адресов, содержащихся в них, существует благодаря концепции относительной адресации . Так что же это такое?

Дело в том, что Excel понимает адреса ячеек введенных в формулу не как ссылку на их реальное месторасположение, а как ссылку на их месторасположение относительно ячейки, в которой находится формула. Поясним на примере.

Например, ячейка A3, содержит формулу: «=A1+A2». Для Excelэто выражение не означает, что нужно взять значение из ячейки A1 и прибавить к нему число из ячейки A2. Вместо этого он интерпретирует данную формулу, как «взять число из ячейки расположенной в том же столбце, но на две строки выше и сложить его со значением ячейки этого же столбца расположенной выше на одну строку». При копировании данной формулы в другую ячейку, например D3, принцип определения адресов ячеек входящих в выражение остается тем же: «взять число из ячейки расположенной в том же столбце, но на две строки выше и сложить его с…». Таким образом, после копирования в D3, исходная формула автоматически примет вид «=D1+D2».

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

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

С помощью абсолютных ссылок можно дать команду Excel при копировании формулы:

  • сохранять ссылку на столбец постоянно, но при этом изменять ссылки на столбцы
  • изменять ссылки на строки, но сохранять ссылку на столбец
  • сохранять постоянными ссылки, как на столбец, так и на строку.
  • $A$1 - ссылка всегда ссылается на ячейку A1 (абсолютная ссылка);
  • A$1 - ссылка всегда ссылается на строку 1, а путь к столбцу может изменяться (смешанная ссылка);
  • $A1 - ссылка всегда ссылается на столбец A, а путь к строке может изменяться (смешанная ссылка).

Для ввода абсолютных и смешанных ссылок используется клавиша «F4». Выделите ячейку для формулы, введите знак равенства (=) и кликните по клетке, на которую надо установить абсолютную ссылку. Затем нажмите клавишу F4, после чего перед буквой столбца и номером строки программа установит знаки доллара ($). Повторные нажатия на F4 позволяют переходить от одного типа ссылок к другим. Например, ссылка на E3, будет циклично изменяться на $E$3, E$3, $E3, E3 и так далее. При желании знаки $ можно вводить вручную.

Функции

Функциями в Excel называют заранее определенные формулы, с помощью которых выполняются вычисления в указанном порядке по заданным величинам. При этом вычисления могут быть как простыми, так и сложными.

Например, определение среднего значения пяти ячеек можно описать формулой: =(A1 + A2 + A3 + A4 + A5)/5, а можно специальной функцией СРЗНАЧ, которая сократит выражение до следующего вида: СРЗНАЧ(А1:А5). Как видите, что вместо ввода в формулу всех адресов ячеек можно использовать определенную функцию, указав ей в качестве аргумента их диапазон.

Для работы с функциями в Excel на ленте существует отдельная закладка Формулы , на которой располагаются все основные инструменты для работы с ними.

Надо отметить, что программа содержит более двухсот функций, способных облегчить выполнение вычислений различной сложности. Поэтому все функции в Excel 2010 разделены на несколько категорий, группирующих их по типу решаемых задач. Какие именно эти задачи, становится ясно из названий категорий: Финансовые, Логические, Текстовые, Математические, Статистические, Аналитические и так далее.

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

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

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

Многие функции могут иметь сразу несколько аргументов. В таком случае, каждый из них отделяется от следующего точкой с запятой. Например, функция =ПРОИЗВЕД(7; A1; 6; B2) считает произведение четырёх разных чисел, указанных в скобках, и соответственно содержит четыре аргумента. При этом в нашем случае одни аргументы указаны явно, а другие, являются значениями определенных ячеек.

Так же в качестве аргумента можно использовать другую функцию, которая в этом случае называется вложенной . Например, функция =СУММ(A1:А5; СРЗНАЧ(В5:В10)) суммирует значения ячеек находящихся в диапазоне от А1 до А5, а так же среднее значение чисел, размещенных в клетках В5, В6, В7, В8, В9 и В10.

У некоторых простых функций аргументов может не быть вовсе. Так, с помощью функции =ТДАТА() можно получить текущие время и дату, не используя никаких аргументов.

Далеко не все функции в Ecxel имеют простое определение, как функция СУММ, осуществляющая суммирование выбранных значений. Некоторые из них имеют сложное синтаксическое написание, а так же требуют много аргументов, которые к тому же должны быть правильных типов. Чем сложнее функция, тем сложнее ее правильное составление. И разработчики это учли, включив в свои электронные таблицы помощника по составлению функций для пользователей - Мастер функций .

Для того что бы начать вводить функцию с помощью Мастера функций , щелкните на значок Вставить функцию (fx) , расположенный слева от Строки формул .

Так же кнопку Вставить функцию вы найдете на ленте сверху в группе Библиотека функций во вкладке Формулы . Еще одним способом вызова мастера функций является сочетание клавиш Shift+ F3 .

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

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

Сделав необходимый выбор, щелкните по кнопке ОК, после чего появится окно Аргументы функции.

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

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

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

Повторное нажатие на нее же приведет к восстановлению обычного размера.

После ввода всех необходимых значений, остается кликнуть по кнопке ОК и в выбранной ячейке появится результат вычисления.

Диаграммы

Довольно часто числа в таблице, даже отсортированные должным образом, не позволяют составить полную картину по итогам вычислений. Что бы получить наглядное представление результатов, в MS Excel существует возможность построения диаграмм различных типов. Это может быть как обычная гистограмма или график, так и лепестковая, круговая или экзотическая пузырьковая диаграмма. Более того, в программе существует возможность создавать комбинированные диаграммы из различных типов, сохраняя их в качестве шаблона для дальнейшего использования.

Диаграмму в Excel можно разместить либо на том же листе, где уже находится таблица, и в таком случае она называется «внедренной», либо на отдельном листе, который станет называться «лист диаграммы».

В качестве примера, попробуем представить в наглядном виде данные ежемесячных расходов, указанных в таблице, созданной нами в предыдущих двух частях материалов «Excel 2010 для начинающих».

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

Затем, на ленте во вкладке Вставка в группе Диаграммы выберите нужный тип и вид диаграммы. Что бы увидеть краткое описание того или иного типа и вида диаграмм, необходимо задержать на нем указатель мыши.

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

В нашем примере давайте выберем объемную цилиндрическую гистограмму с накоплением и нажмем кнопку ОК, после чего на рабочем листе появится диаграмма.

Так же обратите внимание, на появление дополнительной закладки на ленте Работа с диаграммами , содержащая еще три вкладки: Конструктор , Макет и Формат .

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

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

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

Форматирование и изменение диаграмм

При первичном создании диаграммы заранее очень трудно определить, какой ее тип представит наиболее наглядно выбранные табличные данные. Тем более, вполне вероятно, что расположение новой диаграммы на листе окажется совсем не там, где вам хотелось бы, да и ее размеры вас могут не устраивать. Но это не беда - первоначальный тип и вид диаграммы можно легко изменить, так же ее можно переместить в любую точку рабочей области листа или скорректировать горизонтальные и вертикальные размеры.

Что быстро изменить тип диаграммы на вкладке Конструктор в группе Тип , размещающейся слева, щелкните кнопку Изменить тип диаграммы . В открывшемся окне слева выберите сначала подходящий тип диаграммы, затем ее подтип и нажмите кнопку ОК. Диаграмма будет автоматически перестроена. Старайтесь подбирать такой тип диаграммы, который наиболее точно и наглядно будет демонстрировать цель ваших вычислений.

Если данные на диаграмме отображаются не должным образом, попробуйте поменять местами отображения строк и столбцов, нажав на кнопку, Строка/столбец в группе Данные на вкладке Конструктор .

Подобрав нужный тип диаграммы, можно поработать на ее видом, применив к ней встроенные в программу макеты и стили. Excel, за счет встроенных решений, предоставляет пользователям широкие возможности выбора взаимного расположения элементов диаграмм, их отображения, а так же цветового оформления. Выбор нужного макета и стиля осуществляется на вкладке Конструктор в группах с говорящими названиями Макеты диаграмм и Стили диаграмм . При этом в каждой из них есть кнопка Дополнительные параметры , раскрывающая полный список предлагаемых решений.

И все же не всегда созданная или отформатированная диаграмма с помощью встроенных макетов и стилей удовлетворяет пользователей целиком и полностью. Слишком большой размер шрифтов, очень много места занимает легенда, не в том месте находятся подписи данных или сама диаграмма слишком маленькая. Словом, нет предела совершенству, и в Excel, все, что вам не нравится, можно исправить самостоятельно на свой «вкус» и «цвет». Дело в том, что диаграмма состоит из нескольких основных блоков, которые вы можете форматировать.

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

Область построения диаграммы - включает в себя вертикальную и горизонтальную оси, ряд данных, а так же основные и дополнительные линии сетки (стены).

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

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

Линии сетки - наглядно представляют значения осей и размещаются на боковых панелях, называемых стенами .

Легенда - расшифровка значений рядов или строк.

Любому пользователю Excel предоставляется возможность самостоятельно изменять стили и художественное представление каждого из вышеперечисленных компонентов диаграммы. К вашим услугам выбор цвета заливки, стиля границ, толщины линий, наложение объема, теней, свечения и сглаживания на выбранные объекты. В любой момент, можно изменить общий размер диаграммы, увеличить/уменьшить любую ее область, например, увеличить саму диаграмму и уменьшить легенду, или вообще отменить отображение ненужных элементов. Можно изменить угол наклона диаграммы, повернуть ее, сделать объемной или плоской. Одним словом, MS Excel 2010 содержит инструменты, позволяющие придать диаграмме собственноручно наиболее удобный для восприятия образ.

Для изменения компонентов диаграммы воспользуйтесь вкладкой Макет , расположенной на ленте в области Работа с диаграммами .

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

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

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

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

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

В итоге, в окне Формат ряда данных мы убрали фронтальный зазор, а боковой сделали равным 20%, добавили тень снаружи и немного объема сверху.

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

Для форматирования осей давайте воспользуемся вкладкой Макет на ленте сверху. В группе Оси щелкните по одноименной кнопке, выберите нужную ось, а затем пункт Дополнительные параметры основной горизонтальной/вертикальной оси .

Принцип расположения управляющих элементов в открывшемся окне Формат оси мало чем отличается от предыдущих - тот же столбец с параметрами слева и зоной изменяемых значений справа. Здесь мы не стали особо ничего менять, лишь добавив светло-серые тени к подписям значений, как вертикальной, так и горизонтальной осей.

Наконец, давайте добавим заголовок диаграммы, щелкнув на вкладке Макет в группе Подписи по кнопке Название диаграммы . Далее уменьшим область легенды, увеличим область построения и посмотрим, что у нас получилось:

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

Спарклайны или инфокривые

Завершая тему диаграмм в электронных таблицах, давайте рассмотрим новый инструмент наглядного представления данных, который стал доступен в Ecxel 2010. Спарклайны или инфокривые - это небольшие диаграммы, размещающиеся в одной ячейке, которые позволяют визуально отобразить изменение значений непосредственно рядом с данными.

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

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

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

Теперь выберем нужную пустую ячейку во вновь созданном столбце, например H5. Далее на ленте во вкладке Вставка в группе Спарклайны выберете походящий тип кривой: График , Гистограмма или Выигрыш/Проигрыш .

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

В этом примере, вы можете визуально наблюдать динамику изменения общих доходов за полугодие, которую мы отобразили в виде графика. Кстати, что бы построить спарклайны в оставшихся ячейках строк «Зарплата» и «Бонусы», нет никакой необходимости проделывать все вышеописанные действия заново. Достаточно вспомнить и воспользоваться уже известной нам функцией автозаполнения.

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

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

Теперь, после добавления спарклайнов, наша сводная таблица приняла вот такой интересный вид:

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

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

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

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

Заключение

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

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

Варианты записи функции ПРОСМОТР

Начнем с того, что функция ПРОСМОТР имеет две формы записи: векторная и массив. Вводя функцию на рабочий лист, Excel напоминает Вам об этом следующим образом:

Форма массива

Форма массива очень похожа на функции ВПР и ГПР . Основная разница в том, что ГПР ищет значение в первой строке диапазона, ВПР в первом столбце, а функция ПРОСМОТР либо в первом столбце, либо в первой строке, в зависимости от размерности массива. Есть и другие отличия, но они менее существенны.

Данную форму записи мы подробно разбирать не будем, поскольку она давно устарела и оставлена в Excel только для совместимости с ранними версиями программы. Вместо нее рекомендуется использовать функции ВПР или ГПР .

Векторная форма

Функция ПРОСМОТР (в векторной форме) просматривает диапазон, который состоит из одной строки или одного столбца. Находит в нем заданное значение и возвращает результат из соответствующей ячейки второго диапазона, который также состоит из одной строки или столбца.

Вот это да! Это ж надо такое понаписать… Чтобы стало понятней, рассмотрим небольшой пример.

Пример 1

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

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

Первым аргументом функции ПРОСМОТР является ячейка C1, где мы указываем искомое значение, т.е. фамилию. Диапазон B1:B7 является просматриваемым, его еще называют просматриваемый вектор. Из соответствующей ячейки диапазона A1:A7 функция ПРОСМОТР возвращает результат, такой диапазон также называют вектором результатов. Нажав Enter , убеждаемся, что все верно.

Пример 2

Функцию ПРОСМОТР в Excel удобно использовать, когда векторы просмотра и результатов относятся к разным таблицам, располагаются в отдаленных частях листа или же вовсе на разных листах. Самое главное, чтобы оба вектора имели одинаковую размерность.

На рисунке ниже Вы можете увидеть один из таких примеров:

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

При использовании функции ПРОСМОТР в Excel значения в просматриваемом векторе должны быть отсортированы в порядке возрастания, иначе она может вернуть неверный результат.

Так вот коротко и на примерах мы познакомились с функцией ПРОСМОТР и научились использовать ее в рабочих книгах Excel. Надеюсь, что данная информация оказалась для Вас полезной, и Вы обязательно найдете ей применение. Всего Вам доброго и успехов в изучении Excel.

Статьи по теме: