メインコンテンツへスキップ

Kutools for Office — 1つのスイート、5つのツールで、もっと多くのことを成し遂げましょう。

Excelで複数の空列を迅速に削除するにはどうすればよいですか?

Author Kelly Last modified

Webページ、CSV、テキストなどからMicrosoft Excelにデータをインポートするとき、多くの空列が含まれることがあります。それぞれの空列を一つずつ削除するのは時間がかかるため、簡単な方法を探している人も多いでしょう。この記事では、複数の空列を迅速に削除するためのいくつかの便利なヒントを集めました。

数式を使用してワークシート内の複数の空列を削除する

VBAコードを使用してワークシート内の複数の空列を削除する

選択した範囲/現在のシート/全体のワークブック内でKutools for Excelを使って複数の空列を削除する

ヘッダー付きの複数の空列をVBAコードを使用して削除する


数式を使用してワークシート内の複数の空列を削除する

Excelでは、列が空白かどうかを識別するために数式を適用し、その後「並べ替え」機能を使用してすべての空白列をまとめて並べ替え、一括で削除することができます。以下の手順で行ってください:

1. データ範囲の一番上に新しい行を追加します。スクリーンショットをご覧ください:

Add a new row at the top of your data range

2. 次に、以下の数式をセルA1に入力し、他のセルにもこの数式を適用するために右側にフィルハンドルをドラッグします。列が空白の場合、「TRUE」が表示され、それ以外の場合は「FALSE」が表示されます。スクリーンショットをご覧ください:

=COUNTA(A2:A1048576)=0

enter a formula to check if the column is blank

3. その後、ヘルパー行を含むデータ範囲を選択し、「データ」>「並べ替え」をクリックします。スクリーンショットをご覧ください:

click Data > Sort

4. 表示された「並べ替え」ダイアログボックスで、「オプション」ボタンをクリックします。「並べ替えオプション」ダイアログで、「左から右へ並べ替える」オプションを選択します。スクリーンショットをご覧ください:

click Options button arrow right select Sort left to right option

5. 「OK」ボタンをクリックして「並べ替え」ダイアログに戻り、「並べ替え対象」ドロップダウンから「行1」を選択し、「ソート基準」セクションから「セルの値」を選択し、「順序」セクションから「最大から最小へ」を選択します。スクリーンショットをご覧ください:

specify the options in the dialog box

6. これで、すべての空列がデータの左側に並べ替えられます。次に、すべての列を選択し、右クリックして「削除」を選択することで、これらの空白列を一度に削除できます。スクリーンショットをご覧ください:

all empty columns have been sorted at the left of your data,then, delete them


VBAコードを使用してワークシート内の複数の空列を削除する

VBAマクロを使用したい場合、作業はさらに簡単になります。次のVBAコードが役立つかもしれませんので、以下の手順で行ってください:

1. Excelで「Alt + F11」キーを押すと、「Microsoft Visual Basic for Applications」ウィンドウが開きます。

2. 「挿入」>「モジュール」をクリックし、次のマクロをモジュールウィンドウに貼り付けます。

VBAコード:選択範囲内の複数の空白列を削除する:

Sub DeleteEmptyColumns()
'Updateby Extendoffice
Dim rng As Range
Dim InputRng As Range
xTitleId = "KutoolsforExcel"
Set InputRng = Application.Selection
Set InputRng = Application.InputBox("Range :", xTitleId, InputRng.Address, Type:=8)
Application.ScreenUpdating = False
For i = InputRng.Columns.Count To 1 Step -1
    Set rng = InputRng.Cells(1, i).EntireColumn
    If Application.WorksheetFunction.CountA(rng) = 0 Then
        rng.Delete
    End If
Next
Application.ScreenUpdating = True
End Sub

3. F5キーを押してこのマクロを実行し、ポップアップダイアログで必要な作業範囲を選択します。スクリーンショットをご覧ください:

vba code to select the data range

4. 「OK」をクリックすると、選択範囲内のすべての空列が削除されます。スクリーンショットをご覧ください:

all empty columns in the selection are removed


選択した範囲/現在のシート/全体のワークブック内でKutools for Excelを使って複数の空列を削除する

Kutools for Excelの「非表示(表示)されている行や列を削除」ユーティリティを使用すると、複数の空行や空列を一度に簡単に削除できます。

Kutools for Excelは、300以上の高度な機能を提供し、複雑なタスクを簡素化し、創造性と効率を向上させます。 AI機能と統合され、Kutoolsは正確にタスクを自動化し、データ管理を容易にします。Kutools for Excelの詳細情報...無料トライアル...

Kutools for Excelをインストール後、以下のように操作してください:

1. 「Kutools」>「削除」>「非表示(表示)されている行や列を削除」をクリックします。スクリーンショットをご覧ください:

click Delete Hidden (Visible) Rows & Columns feature of kutools

2. 「非表示(表示)されている行や列を削除」ダイアログボックスで、操作を適用する範囲を「検索対象」ドロップダウンリストから指定します。(「選択した範囲内」を選択した場合、最初に使用したい範囲を選択する必要があります。)そして、「削除タイプ」で「列」をチェックし、「詳細なタイプ」から「空白の列」を選択します。スクリーンショットをご覧ください:

set the options in the dilaog box

3. 「OK」をクリックすると、選択した範囲から空白の列が削除されます。スクリーンショットをご覧ください:

the blank columns have been deleted from the selected range


VBAコードを使用してヘッダー付きの複数の空列を削除する

時々、ワークシート内のヘッダーのみがあるすべての空列を削除したい場合があります。次のVBAコードはそのお手伝いをしますので、以下の手順で行ってください:

Delete multiple empty columns with a header

1. Excelで「Alt + F11」キーを押すと、「Microsoft Visual Basic for Applications」ウィンドウが開きます。

2. 「挿入」>「モジュール」をクリックし、次のマクロをモジュールウィンドウに貼り付けます。

VBAコード:ヘッダー付きのすべての空列を削除する

Sub deleteblankcolwithheader()
'updateby Extendoffice
    Dim xEndCol As Long
    Dim I As Long
    Dim xDel As Boolean
    On Error Resume Next
    xEndCol = Cells.Find("*", SearchOrder:=xlByColumns, SearchDirection:=xlPrevious).Column
    If xEndCol = 0 Then
        MsgBox "There is no data on """ & ActiveSheet.Name & """ .", vbExclamation, "Kutools for Excel"
        Exit Sub
    End If
    Application.ScreenUpdating = False
    For I = xEndCol To 1 Step -1
        If Application.WorksheetFunction.CountA(Columns(I)) <= 1 Then
            Columns(I).Delete
            xDel = True
        End If
    Next
    If xDel Then
        MsgBox "All blank column(s) with only a header row have been deleted.", vbInformation, "Kutools for Excel"
    Else
        MsgBox "There are no Columns to delete as each one has more data (rows) than just a header.", vbExclamation, "Kutools for Excel"
    End If
    Application.ScreenUpdating = True
End Sub

3. F5キーを押してこのコードを実行すると、ヘッダー付きの空列が削除されることを知らせるプロンプトボックスが表示されます。スクリーンショットをご覧ください:

a prompt box will pop out to remind you the blank columns with header will be deleted

4. 「OK」ボタンをクリックすると、現在のワークシート内のヘッダーのみがあるすべての空列が一度に削除されます。スクリーンショットをご覧ください:

original data arrow right all the blank columns with only header in current worksheet are deleted

関連記事:

  • Excelで隠し行または隠し列をすべて削除する
  • 大量の隠し行や隠し列を持つ大きなワークブックがあり、隠しデータが不要になった場合、それらをすべて削除したいと思うでしょう。どのようにすれば素早く削除できるでしょうか?
  • Excelで背景色に基づいて行を削除する
  • 背景色に基づいて行全体を削除するにはどうすればよいでしょうか?この例では、次のスクリーンショットに示すように、青色の背景色で塗りつぶされたセルを持つすべての行を削除する必要があります。この記事では、Excelでこのタスクを達成するためのいくつかのコードを紹介します。

最高のオフィス業務効率化ツール

🤖 Kutools AI Aide:データ分析を革新します。主な機能:Intelligent Executionコード生成カスタム数式の作成データの分析とグラフの生成Kutools Functionsの呼び出し……
人気の機能重複の検索・ハイライト・重複をマーキング空白行を削除データを失わずに列またはセルを統合丸める……
スーパーLOOKUP複数条件でのVLookup複数値でのVLookup複数シートの検索ファジーマッチ……
高度なドロップダウンリストドロップダウンリストを素早く作成連動ドロップダウンリスト複数選択ドロップダウンリスト……
列マネージャー指定した数の列を追加列の移動非表示列の表示/非表示の切替範囲&列の比較……
注目の機能グリッドフォーカスデザインビュー強化された数式バーワークブック&ワークシートの管理オートテキスト ライブラリ日付ピッカーデータの統合セルの暗号化/復号化リストで電子メールを送信スーパーフィルター特殊フィルタ(太字/斜体/取り消し線などをフィルター)……
トップ15ツールセット12 種類テキストツールテキストの追加特定の文字を削除など)50種類以上のグラフガントチャートなど)40種類以上の便利な数式誕生日に基づいて年齢を計算するなど)19 種類の挿入ツールQRコードの挿入パスから画像の挿入など)12 種類の変換ツール単語に変換する通貨変換など)7種の統合&分割ツール高度な行のマージセルの分割など)… その他多数
Kutoolsはお好みの言語で利用可能 ― 英語、スペイン語、ドイツ語、フランス語、中国語、その他40以上の言語に対応!

Kutools for ExcelでExcelスキルを強化し、これまでにない効率を体感しましょう。 Kutools for Excelは300以上の高度な機能で生産性向上と保存時間を実現します。最も必要な機能はこちらをクリック...


Office TabでOfficeにタブインターフェースを追加し、作業をもっと簡単に

  • Word、Excel、PowerPointでタブによる編集・閲覧を実現
  • 新しいウィンドウを開かず、同じウィンドウの新しいタブで複数のドキュメントを開いたり作成できます。
  • 生産性が50%向上し、毎日のマウスクリック数を何百回も削減!

全てのKutoolsアドインを一つのインストーラーで

Kutools for Officeスイートは、Excel、Word、Outlook、PowerPoint用アドインとOffice Tab Proをまとめて提供。Officeアプリを横断して働くチームに最適です。

Excel Word Outlook Tabs PowerPoint
  • オールインワンスイート — Excel、Word、Outlook、PowerPoint用アドインとOffice Tab Proが含まれます
  • 1つのインストーラー・1つのライセンス —— 数分でセットアップ完了(MSI対応)
  • 一括管理でより効率的 —— Officeアプリ間で快適な生産性を発揮
  • 30日間フル機能お試し —— 登録やクレジットカード不要
  • コストパフォーマンス最適 —— 個別購入よりお得