Excel 文字列を比較する方法(完全一致・部分一致)
Excelには文字列が一致しているかを調べる機能が複数あります。
その機能には完全一致を調べるものと部分一致を調べる、あいまい検索があります。
これらは主にIF関数や条件付き集計関数、XLOOKUP関数、VLOOKUP関数に用いるものです。
この記事では文字列比較機能のそれぞれの特徴と適切な場面を紹介します。
完全一致
比較演算子
文字列が全て一致している場合にTRUEとなります。
方法は単純に"(ダブルコーテーション)で囲んだ文字列同士を=で挿んだ数式を作ります。
=文字列1 = 文字列2
IF関数の場合の使用例です。
一字一句違いのない場合のみTRUEとなります。
3行目のように検査対象を含んでいたとしても異なっていると判断されてFALSEとなります。
この比較演算子は手軽に使用できますが、大文字小文字を区別しないなど
比較が厳密でない部分があるため厳密な比較を行いたい場合はEXACT関数を使用します。
EXACT関数
比較演算子とは下記の差があるのでその時々で都合のよいほうを利用します。
「半角文字の数字」と「数値」の比較 | ・=ではデータ型が違うと別と判定 ・EXACT関数では数値が一緒であれば同じと判定 |
アルファベットの大文字と小文字 | ・=では大文字と小文字を区別しない ・EXACT関数では大文字と小文字を区別する |
EXACT関数はこのように使用します。
=EXACT(文字列1,文字列2)
下記がEXACT関数の結果例と比較演算子の結果との対比です。
部分一致の例
含むパターン(部分一致)や
前方一致(先頭が一致)、後方一致(末尾が一致)の場合、
ワイルドカードという特殊な文字で数式を作ります。
主に条件付き集計関数、 XLOOKUP関数、VLOOKUP関数に使用します。
IF関数にはそのままでは使えません(後述)。
このワイルドカードには下記のものがあります。
文字 | 読み方 | 用途 |
---|---|---|
* | アスタリスク | 同じ位置の任意の数の文字列 |
? | クエスチョン | 同じ位置の任意の1文字 |
~ | チルダ | アスタリスクとクエスチョンを通常の文字として扱う |
条件付き集計関数やVLOOKUP関数での使用例
?は任意の文字数が何文字かを明確に指定したい場合に使用します。
逆に文字数を特定しない場合は*を使用します。
これによりVLOOKUP関数や条件付き集計関数であいまい検索を実現できます。
(XLOOKUP関数では一致モードを変更する必要があります)
比較方法 | 数式例 |
---|---|
部分一致 | *文字列* |
前方一致 | 文字列* |
後方一致 | *文字列 |
IF関数での使用例
IF関数にはワイルドカードが使えませんが
COUNTIF関数を間に挟むことで機能させることが可能です。
=IF(COUNTIF(検索対象,"*文字列*")>=1,"含む","含まない")
※>=1はなくても機能します。
FILTER関数の場合
FILTER関数の場合、ワイルドカードが利用できないため文字列関数で対応する必要があります。
(詳細はFILTER関数の記事内)
Excel完全マスター: 関数・テクニック・新機能を網羅した決定版ガイド
本書は、Excelの基礎から応用まで、包括的に学べるガイドブックです。当サイトの豊富な情報を、電子書籍向けに最適化し、読みやすく再構成しました。
【本書の特徴】
- 情報量:Word-A4サイズ換算で1,400ページ相当
- 基本操作から高度なテクニックまで、段階的に学習可能
- 140種類の関数を詳細に解説
- 109種類の実用的なテクニックと具体例を紹介
- 最新機能(XLOOKUP関数、LET関数、シートビュー、LAMBDA関数、スピル等)を徹底解説
【対象読者】
- Excel初心者からプロフェッショナルまで
- 体系的にExcelスキルを向上させたい方
- 業務効率化を目指すビジネスパーソン
- データ分析や可視化のスキルを磨きたい方
【本書の強み】
- 実務に即した例題と解説
- 視覚的な図表やスクリーンショットで理解を促進
- 最新のExcelバージョンに対応した内容
- 著者の長年の経験に基づく、実践的なTipsを多数収録
【更新とサポート】
- 常に最新の情報を反映するため、定期的に内容を更新
- 最新版の入手方法:Amazonカスタマーサポートへお問い合わせください
【入手方法】
- 買い切り:950円
- Kindle Unlimited:読み放題プランで利用可能
Excelマスターを目指す方、業務効率を劇的に向上させたい方に、自信を持っておすすめできる一冊です。この1冊で、Excelの可能性を最大限に引き出す力が身につきます。