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

Excelで月を年と月に変換するにはどうすればよいですか?

Author: Xiaoyang Last Modified: 2025-08-06
convert months to years and months

Excelのワークシートで、月単位の値を年と月の形式に変換しようとしたことはありますか?例えば、56ヶ月がある場合、それを4年8ヶ月として表示したいと思うかもしれません。左の画像に示すように、月を読みやすい年と月の形式に変換することで、特に期間や勤続年数を報告する際に明確さが向上します。この記事では、Excelでこのタスクを実行するための実用的な方法を探り、それぞれのアプローチがどのシナリオで最も役立つかを議論します。

数式を使用して月を年と月に変換する

VBAマクロを使用して月を年と月に変換する


数式を使用して月を年と月に変換する

月を表す数値を、より理解しやすい年と月の期間に変換したい場合、Excelの数式はこれを効率的に達成できます。この方法は、日常的なタスク、小さなデータセット、またはコードを使用したくない場合に特に便利です。数式は動的であるため、入力された月が変わると結果も自動的に更新されます。

数式を使って直接月を年と月に変換するには、以下の方法を使用できます。この解決策では、完全な年は総月数を12で割ることで計算され、余りが残りの月数となります:

次の数式を空白のセルにコピーして貼り付けてください:

=INT(A2/12) & " 年と " &MOD(A2,12)& " 月"

この数式を入力したら、Enterキーを押して年と月への変換を確認します。数式を追加の行に適用するには、リストの横でフィルハンドルを下にドラッグします。この手法により、すべての値が即座に変換され、一括処理が簡単に行えます。

Convert months to years and months with formula

ヒントと注意点:

  • 月数が12未満の場合、数式は「0年とX月」と表示します。
  • 負の値や整数以外の値は予期しない結果を引き起こす可能性があります。ソース値が有効であり、数値としてフォーマットされていることを確認してください。
  • 入力がない場合に空白を表示するには、「0年と0月」と表示されないようにIF関数を使用できます。

一般的なトラブルシューティング:

  • #VALUE!エラーが表示される場合は、参照されているセルに有効な数値が含まれているか確認してください。
  • 出力フォーマットをカスタマイズしたい場合は、必要に応じて数式内の引用符内のテキストを調整してください。

この数式の方法は、値が変わる可能性のある動的変換に適しており、プログラミングやマクロにあまり詳しくないユーザーにも適しています。非常に大きなデータセットや頻繁で反復的な変換には、自動化されたアプローチの方が効率的かもしれません。以下に、マクロベースの解決策を示します。



VBAマクロを使用して月を年と月に変換する

月のリストを定期的に年と月の形式に変換する必要がある場合、または非常に大きなデータセットを扱っている場合、ExcelのVBAマクロ機能を使用してこのタスクを自動化し、時間を節約し、手動でのエラーを減らすことができます。マクロを使用するのは、複数の列を処理したり、新しいデータにロジックを適用したりする繰り返し可能なワークフローの一部として行う場合に特に価値があります。

1. 開発タブをクリックしてVisual BasicをクリックしてVBAエディターを開きます。開発タブが表示されていない場合は、Excelオプション>リボンのユーザー設定から有効にできます。エディターが開いたら、挿入>モジュールをクリックします。現れたモジュールウィンドウに次のコードをコピーして貼り付けます:

Sub ConvertMonthsToYearsMonths()
    Dim rng As Range
    Dim cell As Range
    Dim years As Integer
    Dim months As Integer
    Dim outputCol As Long
    
    On Error Resume Next
    xTitleId = "KutoolsforExcel"
    Set rng = Application.InputBox("Select the range of months to convert", xTitleId, Selection.Address, Type:=8)
    
    If rng Is Nothing Then Exit Sub
    
    outputCol = rng.Columns(rng.Columns.Count).Column + 1
    
    For Each cell In rng
        If IsNumeric(cell.Value) And cell.Value >= 0 Then
            years = Int(cell.Value / 12)
            months = cell.Value Mod 12
            cell.Offset(0, rng.Columns.Count).Value = years & " years and " & months & " months"
        Else
            cell.Offset(0, rng.Columns.Count).Value = ""
        End If
    Next
End Sub

2マクロを実行するには、 Run button ボタンをクリックするか、 F5キーを押します。ダイアログボックスが表示され、変換したい月の範囲を選択するよう求められます(例:A2:A20)。範囲を選択してOKをクリックします。

マクロは自動的に結果(「X年とY月」形式)を選択した列のすぐ右隣の列に書き込みます。例えば、A2:A20を選択した場合、結果はB2:B20に配置されます。

使用上の注意とヒント:

  • 選択範囲に有効な正の数値である月が含まれていることを確認してください。セルが空の場合はゼロと見なされ、「0年と0月」と返されます。非数値や負の値は空白やエラーの出力となる可能性があります。
  • マクロは選択範囲のすぐ右隣の列に出力結果を返します。マクロを実行する前にその列を確認して、データが上書きされないように注意してください。
  • このマクロは何度でも実行できるため、バッチ処理や新しいデータの投入に便利です。
  • VBA操作に対して元に戻す(Ctrl+Z)は利用できないため、マクロを実行する前に重要なデータのバックアップコピーを必ず保管してください。
  • データに負の月や分数の月が含まれる場合、これらは空白として扱われます(VBA条件を参照、必要に応じて修正してください)。

このVBAアプローチは、繰り返しの変換が必要なユーザー、一度に多くの行を処理する必要があるユーザー、または生産性タスクを自動化する必要があるユーザーにとって実用的です。ワンクリックでデータセット全体を変換し、ワークフローを合理化できます。ただし、VBA初心者の場合は、マクロが有効になっていることを確認し、環境でマクロ制限がある場合はIT管理者に相談してください。

トラブルシューティング:

  • マクロを実行中にエラーが発生した場合、開発タブが有効で、Excel設定でマクロが許可されていることを確認してください。
  • 結果が既存のデータを上書きする場合、マクロを実行する前に隣の列が空いていることを確認してください。
  • 誤って間違った範囲を選択した場合、マクロを再実行して再度選択してください。

まとめると、数式とVBAの両方のソリューションにより、月を読みやすい年と月の形式に変換することが簡単かつ効率的になります。データセットのサイズやワークフローの好みに最も適した方法を選んでください。さらに自動化するには、特別なフォーマットや出力ニーズに対応するためにVBAコードをさらにカスタマイズできます。


関連記事:

  • Excelで日付を月と年だけで比較する
  • 2つの日付リストがあり、日付を月と年だけで比較し、日付部分を無視したい場合、同じ月と年の場合は結果がTrue、それ以外の場合はFalseと表示すべきです。次のスクリーンショットに示すように、Excelでどのように日付を月と年だけで比較するにはどうすればよいですか?
  • Excelで月と年に基づいて値を集計する
  • データ範囲があり、列Aにはいくつかの日付があり、列Bには注文数がある場合、別の列から月および年に基づいて数字を集計する必要があります。この場合、2016年1月の合計注文数を計算して次の結果を得たいと思います。この記事では、Excelでこのジョブを解決するためのいくつかのトリックについて説明します。
  • Excelで1-12を月名に変換する
  • たとえば、月が数字で表示されている売上表を受け取った場合、数字を通常の月名に変換する必要があります。次に示すスクリーンショットのように、何かアイデアはありますか?この記事では、2つの解決策を紹介します。
  • Excelで月または年内に残りの日数を計算する
  • 特定の場合、月または年内に残りの日数を知りたいことがあります。今日の日付が2014/10/12だと仮定すると、今月(10月)または今年(2014年)の残りの日数を計算したいと思います。つまり、今月は残り19日、今年は残り80日です。詳細については、以下の記事をご覧ください。

  • スーパー数式バー(複数行のテキストや数式を簡単に編集可能); 閲覧レイアウト(多数のセルを簡単に読み取り・編集可能); フィルター範囲への貼り付け...
  • セル/行/列を結合してデータを保持; セル内容を分割; 重複する行を統合して合計/平均を計算... 重複セルを防止; 範囲を比較...
  • 重複または一意の行を選択空白行を選択(すべてのセルが空); スーパー検索および多くのワークブックでのあいまい検索; ランダム選択...
  • 数式参照を変更せずに複数のセルを正確にコピー; 複数のシートへの自動参照作成; 箇条書き、チェックボックスなどを挿入...
  • お気に入りの数式、範囲、グラフ、画像を素早く挿入; パスワードでセルを暗号化メーリングリストを作成してメールを送信...
  • テキストの抽出、テキストの追加、特定の位置の文字を削除、スペースを削除; ページング小計の作成と印刷; セルの内容とコメント間の変換...
  • スーパーフィルター(他のシートにフィルタースキームを保存して適用); 月/週/日ごとの高度な並べ替え、頻度など; 太字、斜体による特殊フィルタリング...
  • ワークブックとワークシートを統合; 主キーカラムに基づいてテーブルをマージ; データを複数のシートに分割xls、xlsx、PDFの一括変換...
  • ピボットテーブルのグループ化(週番号、曜日など)... ロックされたセルとロックされていないセルを異なる色で表示; 数式/名前を持つセルをハイライト...
kte tab 201905
  • Word、Excel、PowerPoint、Publisher、Access、Visio、Projectでタブ付き編集と閲覧を有効化します。
  • 新しいウィンドウではなく、同じウィンドウ内の新しいタブで複数のドキュメントを開き、作成します。
  • 生産性を50%向上させ、毎日数百回のマウスクリックを削減します!
officetab bottom