データ集計やリストアップなど、仕事で何かと使うことも多いエクセル(Excel)やスプレッドシート。
より効率的に使いこなすために注目したいのは、やはり「関数」です。
その関数によって何ができるのか、どういうシチュエーションで活用できるのかを覚えておけば、職場で頼られる存在になれるかも?!
今回は【基本編】【応用編】【かっこいい編】にわけて、知っておきたい関数40選をご紹介します!
この機会に、ぜひ使える関数を増やしてみてくださいね!
エクセルとスプレッドシートの違い
日々の仕事で活用することが多い表計算ツールである、エクセルとスプレッドーシート。
すでに「知っているよ!」という方も多いとは思いますが、改めて2つの表計算ツールについてまとめておきます。
エクセル(Microsoft Excel)とは
マイクロソフト社が開発・販売している表計算ソフト。表やグラフを作成したり、複雑な計算や集計も、簡単に実施・管理することができます。
Windowsと親和性が強いイメージがありますが、macOS、iOSおよびAndroidにも対応しています。
またローカルで動くソフトだけではなく、Web上でつかえるシリーズもあります。
会社支給のパソコンにはすでにセットアップされていることが多いですが、基本的にはすべて有料のツールです。
スプレッドシート(Google スプレッドシート)とは
Google社が開発・提供している表計算ソフト。できることは、エクセルとほぼ同じと言っても問題ないでしょう。
最大の特徴は、Web上で複数人がリアルタイムに編集ができ、何より無料で活用できること。
また自動保存されるため、「この3時間の作業が全部消えた!」というような悲しい事件があまり起きません。
しかも、変更履歴が同時に保存されるため、編集前のデータに戻すことも可能です。
【基本編】絶対に覚えておきたい関数10選
関数とは、表計算ソフトにて目的の計算に導くためのコードのようなもの。
その数は数百種類にも及ぶと言います。
多くの関数はエクセルもスプレッドシートも共通していて、同じように使えます。
中にはエクセルしか活用できないものもありますし、逆にスプレッドシート特有の関数もあります。
ここではまず、両者に共通する絶対に覚えておくべき10の関数をご紹介します。
関数を使って、どんなことができるのか、その基本を覚えましょう!
ここで紹介するのは、この関数!
IF関数、SUM関数、COUNT関数、AVERAGE関数、VLOOKUP関数、TODAY関数・NOW関数、YEAR関数 / MONTH関数 / DAY関数、HOUR関数 / MINUTE関数 / SECOND関数、WEEKDAY関数、MAX関数 / MIN関数
知っている方は【応用編】にジャンプ!
IF関数:条件によって利用する式を変える
イフ関数と読みます。
TRUE(真)であれば◯◯、FALES(偽)であれば△△のように、条件によってセルに表示させる内容を変えたい場合に活用できます。
=IF(論理式, 真の場合, 偽の場合)

SUM関数:数値を合計する
サム関数と読みます。
指定した範囲の数値の合計を算出できます。
=SUM(セルの範囲)

COUNT関数:数値や日付、時刻などの個数を求める
カウント関数と読みます。
指定した範囲の数値や日付、時刻の個数を求める時に活用できます。
=COUNT(値1, 値2, …, 値255)

入荷数に数値が記載されているものの数を表示。「入荷なし」のテキストは数値ではないのでカウントしない。
AVERAGE関数:数値の平均を求める
アベレージ関数と読みます。
指定した範囲の数値の平均値を求める際に活用できます。
=AVERAGE(数値1, 数値2, …, 数値255)

VLOOKUP関数:範囲を縦方向に検索する
ブイ・ルックアップ関数と読みます。
縦に並んだデータから検索して、同行にある別の値を表示させたい時に活用できます。検索方法には「TRUE(近似値で検索)」もしくは「FALCE(完全一致)」が指定できます。
=VLOOKUP(検索値, 範囲, 列番号, 検索方法)

TODAY関数・NOW関数:現在の日付を求める
トゥデイ、ナウ関数と読みます。
現在の日付や時刻を表示させたい時に活用できます。スプレッドシートの場合は、「Googleスプレッドシートの設定」で設定したタイムゾーンに依存します。
=TODAY()、=NOW()

YEAR関数 / MONTH関数 / DAY関数:日付から「年・月・日」を取り出す
イヤー、マンス、デイ関数と読みます。
日付のシリアル値から、該当する年・月・日だけを表示させたい時に活用できます。
シリアル値とは:日時を計算処理するための数値です。 起点日(1900年1月1日)と起点時刻(0:00:00)を元に通算した数値です。整数部分は日付を、小数部分は時刻を表しています。「2020/04/01」などを入力すると、自動的に変換されています。
=YEAR(シリアル値)
=MONTH(シリアル値)
=DAY(シリアル値)

HOUR関数 / MINUTE関数 / SECOND関数:時刻から「時・分・秒」を取り出す
アワー、ミニット、セカンド関数と読みます。
時刻のシリアル値から、該当する時・分・秒だけを表示させたい時に活用できます。
=HOUR(シリアル値)
=MINUTE(シリアル値)
=SECOND(シリアル値)

WEEKDAY関数:日付から曜日を取り出す
ウィークデイ関数と読みます。
日付から、該当する曜日を表示させたい時に活用できます。
=WEEKDAY(シリアル値)

MAX関数 / MIN関数:数値の最大値・最小値を求める
マックス、ミニマム関数と読みます。
指定した範囲の数値の中から、最大値や最小値を求めたい時に活用できます。
=MAX(数値1, 数値2, …, 数値255)、=MIN(数値1, 数値2, …, 数値255)

【応用編】基本と一緒に覚えよう!応用型関数15選
ここでは、基本編でご紹介した10の関数を用いて、より複雑な条件設定をしたい時などに活用できる関数をご紹介します。
基本を押さえておけば、簡単に覚えられるものばかり!
ぜひチェックしてみましょう。
ここで紹介するのは、この関数!
IFS関数、IFERROR関数、SUMIF関数、SUMIFS関数、COUNTA関数、COUNTIF関数、COUNTIFS関数、AVERAGEA関数、AVERAGEIF関数、AVERAGEIFS関数、HLOOKUP関数、MAXA関数 / MINA関数、MAXIFS関数 / MINIFS関数、AND関数、OR関数
知っている方は【かっこいい編】にジャンプ!
応用編は
IFS関数:複数の条件を順に調べた結果に応じて異なる値を返す
イフ・エス関数と読みます。
◯であれば「●●」を、△であれば「▲▲」を表示させるなど、複数の条件を順番に調べてそれぞれ異なる結果を表示させたい時に活用できます。条件は127個まで指定できます。
=IFS (論理式1, 真の場合1, 論理式2, 真の場合2, …, 論理式127, 真の場合127)

IFERROR関数:エラーの場合に返す値を指定する
イフ・エラー関数と読みます。
計算結果がエラー値([#DIV/0!][#N/A][#NAME?][#NULL!][#NUM!][#REF!][#VALUE!])の場合に、指定の値を表示させたい時に活用できます。
=IFERROR(値, エラーの場合の値)

SUMIF関数:条件に一致する数値の合計を求める
サム・イフ関数と読みます。
条件を指定して、合致した値のみ合計したい時に活用できます。
=SUMIF(範囲, 検索条件, 合計範囲)

SUMIFS関数:複数の条件を指定して数値を合計する
サム・イフ・エス関数と読みます。
複数の条件に合致した値のみ合計したい時に活用できます。
=SUMIFS(合計範囲, 条件範囲1, 条件1, 条件範囲2, 条件2, …)

COUNTA関数:データの個数を求める
カウント・エー関数と読みます。
指定した範囲のデータの個数を求める時に活用できます。
=COUNTA(値1, 値2, …, 値255)

COUNTIF関数:条件に一致するデータの個数を求める
カウント・イフ関数と読みます。
指定した条件に一致するデータの個数を求めたい時に活用できます。
=COUNTIF(範囲, 検索条件)

COUNTIFS関数:複数の条件に一致するデータの個数を求める
カウント・イフ・エス関数と読みます。
複数の条件に合致したデータの個数を求めたい時に活用できます。
=COUNTIFS(範囲1, 検索条件1, 範囲2, 検索条件2, …)

AVERAGEA関数:データの平均を求める
アベレージ・エー関数と読みます。
指定した範囲の値の平均値を求める際に活用できます。(文字列だとしても1個数としてカウントされます)
=AVERAGEA(値1, 値2, …, 値255)

AVERAGEIF関数:条件を指定して数値の平均を求める
アベレージ・イフ関数と読みます。
条件を指定して、合致した値の平均値のみしたい時に活用できます。
=AVERAGEIF(範囲, 検索条件, 平均対象範囲)

AVERAGEIFS関数:複数の条件を指定して数値の平均を求める
アベレージ・イフ・エス関数と読みます。
複数の条件を指定して、合致した値の平均値のみしたい時に活用できます。
=AVERAGEIFS(平均対象範囲, 条件範囲1, 条件1, 条件範囲2, 条件2, …)

HLOOKUP関数:範囲を横方向に検索する
エイチ・ルックアップ関数と読みます。
横に並んだデータから検索して、同列にある別の値を表示させたい時に活用できます。検索方法には「TRUE(近似値で検索)」もしくは「FALCE(完全一致)」が指定できます。
=HLOOKUP(検索値, 範囲, 行番号, 検索の型)

MAXA関数 / MINA関数:データの最大値・最小値を求める
マックス・エー、ミニマム・エー関数と読みます。
指定した範囲の値の中から、最大値や最小値を求めたい時に活用できます。
=MAXA(値1, 値2, …, 値255)
=MINA(値1, 値2, …, 値255)

MAXIFS関数 / MINIFS関数:複数の条件を指定して最大値・最小値を求める
マックス・イフ・エス、ミニマム・イフ・エス関数と読みます。
複数の条件に合致するデータ内で、最大値・最小値を求めたい時に活用できます。
=MAXIFS(最大範囲, 条件範囲1, 条件1, 条件範囲2, 条件2, …, 条件範囲126, 条件126)

AND関数:すべての条件が満たされているかを調べる
アンド関数と読みます。
指定した条件に対し、そのすべてが満たされているかどうかを検証したい時に活用できます。結果は「TRUE(真)」か「FALSE(偽)」で表示されます。条件は255まで設定できます。
=AND(論理式1, 論理式2, …, 論理式255)

OR関数:いずれかの条件が満たされているかを調べる
オア関数と読みます。
指定した条件に対し、いずれかの条件が満たされているかどうかを検証したい時に活用できます。結果は「TRUE(真)」か「FALSE(偽)」で表示されます。
=OR(論理式1, 論理式2, …, 論理式255)

【かっこいい編】知っているとかっこいい関数10選
ここでご紹介するのは、「こんなこともできるんだ!」と目からウロコの関数10選。
エクセル・スプレッドシートマスターさんは知っているものばかりかもしれませんね!
こちらも合わせてチェックしてみましょう。
UNIQUE関数:重複するデータをまとめる
ユニーク関数と読みます。
重複するデータをまとめて抽出したい時に活用できます。エクセルとスプレッドシートで入力方法が異なりますので、注意が必要です。
また、エクセルでは同じUNIQUE関数を活用して「1回だけ現れたデータ」を抽出することもできます。
=UNIQUE(範囲, 検索方向, 回数)
検索方法:「TRUE」行方向(右方向)、「FALES」列方向(下方向)
回数:「TRUE」1回だけ現れるデータだけを抽出、「FALES」複数回現れるデータは1つにまとめる

=UNIQUE(範囲)

WORKDAY関数:土日と祭日を除外して期日を求める
ワークデイ関数と読みます。
指定した日数後の期日を、土日と祝日を省いて算出したい時に活用できます。
=WORKDAY(開始日, 日数, 祝日)

NETWORKDAYS関数:土日と祝日を除外して期間内の日数を求める
ネットワーク・デイズ関数と読みます。
特定期間の日数を、土日と祝日を省いた日数で算出したい時に活用できます。
=NETWORKDAYS(開始日, 終了日, 祝日)

MEDIAN関数:数値の中央値を求める
メディアン(メジアン)関数と読みます。
平均とは別に中央値を求めたい時に活用できます。
=MEDIAN(数値1, 数値2, …, 数値255)

RANK.EQ / RANK.AVG関数:順位を求める(同じ値のときは最上位・平均値の順位を返す)
ランク・イー・キュー、ランク・アベレージ関数と読みます。
指定したデータの中で、その順位を表示させたい時に活用できます。
順序は「0」を入力すると降順、「0以外の数値」を入力すると昇順の順序になります。
=RANK.EQ(数値, 参照, 順序)
=RANK.AVG(数値, 参照, 順序)

LEN関数:文字列の文字数を求める
レングス関数と読みます。
指定したセル内になる文字数を表示させたい時に活用できます。
=LEN(文字列)

TRIM関数:余計な空白文字を削除する
トリム関数と読みます。
余計な空白を取り除き、きれいなデータを生成したい時に活用できます。
=TRIM(文字列)

SUBSTITUTE関数:指定の文字列を置き換える
サブスティチュート関数と読みます。
文字列の中で、指定の文字を別の文字に置き換えたい時に活用できます。
=SUBSTITUTE(文字列, 検索文字列, 置換文字列, 置換対象)

CONCAT関数:複数の文字列を連結する
コンカット関数と読みます。
いくつかの文字列を連結して、1つのセルにまとめたい時に活用できます。エクセルは
CONCAT関数で複数の文字列を連結できますが、スプレッドシートでは2つの文字列までしか連結できません。スプレッドシートで3つ以上を連結する際は、CONCATENATE関数を活用します。
=CONCAT(文字列1, 文字列2, …, 文字列253)

=CONCATENATE(文字列)

DATESTRING関数:日付を和暦に変換する
デート・ストリング関数と読みます。
日付を和暦(令和2年など)に変換したい時に活用できます。エクセルのみ有効です。
=DATESTRING(シリアル値)

【おまけ】スプレッドシートユーザーなら活用したい特有の関数5選
ここでご紹介するのは、スプレッドシートユーザーさんにはうれしい、Googleツールならではの関数5選です。
「こんなこともできるの?!」と、編集部でも話題になりました。
ぜひ確認してみてくださいね!
GOOGLETRANSLATE関数:テキストをある言語から別の言語に翻訳する
グーグル・トランスレート関数と読みます。
テキストをある言語から別の言語に翻訳したい時に活用できます。便利!
言語は2文字の言語コードで指定します。(日本語:ja、英語:en)
言語コード一覧:https://cloud.google.com/translate/docs/languages?hl=ja
=GOOGLETRANSLATE(テキスト, “ソース言語”,”ターゲット言語”)

DETECTLANGUAGE関数:テキストで使用される言語を識別する
ディテクト・ランゲージ関数と読みます。
「これはいったい何語?」という時に活用できます。
=DETECTLANGUAGE(テキストまたは範囲)

ISURL関数:値が有効な URL であるかどうかを検証する
イズ・ユーアールエル関数と読みます。
文字列がURLとして有効かどうかを検証する際に活用できます。有効であれば
「TRUE」、そうでなければ「FALSE」が表示されます。そのサイトが現在生きているかどうかまでは判断できません。
=ISURL(文字列)

IMAGE関数:セルに画像を挿入する
イメージ関数と読みます。
セル内に画像を挿入・表示したい場合に活用できます。ネット上の誰でもアクセスできる画像、もしくはGoogledrive内にある画像のみ表示できます。
=IMAGE(”URL”)

FILTER関数:指定したデータだけを抽出する
フィルタ関数と読みます。
複数人で同時にスプレッドシートを編集する場合に、自分が見たい範囲だけのデータを抽出できます。
=FILTER(範囲, 条件1, [条件2, …])

編集部から
いかがでしたでしょうか。
今回ご紹介した40の関数のうち、実際に使ったことがあったのはどのくらいありましたか?
活用できる関数を増やすことができれば、「こんな分析がしたい…!」「こんな分析資料をサクッとつくれればいいな…!」という職場の悩みも解決することができるかもしれません!
今回ご紹介した【基本編】だけでも、ぜひ覚えておきましょう!