Excel VBAを用いた従業員別業績レポートの自動生成方法

この記事では、Excel VBAを用いて地域別の販売量を集計する方法について詳しく解説します。基本的なコードの実装から詳細な解説、さらには応用例までを網羅しています。初心者でも分かりやすく、経験者の方もさらなる知識を得ることができる内容となっております。

目次

Excel VBAの基本

Excel VBA(Visual Basic for Applications)は、Microsoft Excelに組み込まれたプログラミング言語です。これを用いると、単純作業の自動化だけでなく、高度なデータ分析やレポート作成も可能になります。

そもそも、どこにVBAコードを書いて、どう実行すれば良いのか分からない場合は、以下の記事をご参照ください。

基本のコード


Sub 地域別販売量集計()
    Dim ws As Worksheet
    Dim LastRow As Long

    ' 集計するワークシートを設定
    Set ws = ThisWorkbook.Sheets("Sheet1")
    
    ' 最後の行を取得
    LastRow = ws.Cells(ws.Rows.Count, "A").End(xlUp).Row
    
    ' 地域別に合計を集計
    ws.Range("C1").Value = "集計結果"
    ws.Range("C2").Resize(LastRow - 1).Formula = "=SUMIF(A:A, A2, B:B)"
End Sub

コードの詳細解説

1. **Worksheetの定義**: まず、操作したいワークシートを指定します。この例では”Sheet1″を操作対象としています。
2. **最終行の取得**: データが入っている最後の行を取得します。これにより、動的な範囲の指定が可能になります。
3. **集計結果の表示**: 地域別の合計をC列に表示します。SUMIF関数を用いて、A列の地域情報を基にB列の販売量を合計しています。

応用例

1. 地域ごとの平均販売量を計算する


Sub 地域別平均販売量()
    Dim ws As Worksheet
    Dim LastRow As Long

    Set ws = ThisWorkbook.Sheets("Sheet1")
    LastRow = ws.Cells(ws.Rows.Count, "A").End(xlUp).Row

    ws.Range("D1").Value = "平均販売量"
    ws.Range("D2").Resize(LastRow - 1).Formula = "=AVERAGEIF(A:A, A2, B:B)"
End Sub

2. 地域ごとの最大・最小販売量を取得する


Sub 地域別最大最小販売量()
    Dim ws As Worksheet
    Dim LastRow As Long

    Set ws = ThisWorkbook.Sheets("Sheet1")
    LastRow = ws.Cells(ws.Rows.Count, "A").End(xlUp).Row

    ws.Range("E1").Value = "最大販売量"
    ws.Range("F1").Value = "最小販売量"
    ws.Range("E2").Resize(LastRow - 1).Formula = "=MAXIFS(B:B, A:A, A2)"
    ws.Range("F2").Resize(LastRow - 1).Formula = "=MINIFS(B:B, A:A, A2)"
End Sub

3. 地域別の販売量のグラフを自動生成する


Sub 地域別販売量グラフ作成()
    Dim ws As Worksheet
    Dim LastRow As Long
    Dim chrt As Chart

    Set ws = ThisWorkbook.Sheets("Sheet1")
    LastRow = ws.Cells(ws.Rows.Count, "A").End(xlUp).Row

    Set chrt = ws.Shapes.AddChart2(251, xlColumnClustered).Chart
    chrt.SetSourceData Source:=ws.Range("A1:C" & LastRow)
    chrt.HasTitle = True
    chrt.ChartTitle.Text = "地域別販売量"
End Sub

まとめ

Excel VBAを活用すれば、地域別の販売量の集計だけでなく、さまざまな応用的な分析やレポート作成が可能です。この記事を通じて、VBAの基本的な使い方や応用テクニックを習得し、効率的なデータ分析を進める手助けとしてください。

VBAも良いけどパワークエリも良い

VBAの解説をしてきましたが、VBAは正直煩雑でメンテナンス性が悪いです。最近はモダンExcelと呼ばれるパワークエリやパワーピボットへのシフトが進んできています。本サイトでもパワークエリの特集をしており、サンプルデータを含む全11回の学習コンテンツでパワークエリを習得することができます。

クリックするとパワークエリの全11講座が表示されます。

パワーピボットの記事はありません。興味がある場合は、書籍で学んでみてください

コメント

コメントする

目次