Microsoft Teamsは、社内外のメンバーとコミュニケーションを取りながらファイルを共有できる非常に便利なツールです。しかし、Teamsのチャットやチャネルに投稿されたExcelファイルをクリックして開いた際、「表のレイアウトが激しく崩れている」「図形やテキストボックスがずれている」「マクロ(ボタン)をクリックしても全く反応しない」といったトラブルに遭遇したことはないでしょうか。

「ファイルが壊れてしまったのではないか?」「自分のパソコンがおかしいのか?」と焦る方も多いですが、安心してください。これはファイルが破損したわけでも、パソコンの不具合でもありません。Teamsのシステム上の「仕様」によって引き起こされている現象です。

この問題は、Teams上でファイルを開く際の「既定の設定」をほんの少し変更するだけで、劇的に改善し、二度とストレスを感じることなくデスクトップ版と同じ環境で作業できるようになります。

本記事では、Teams上でExcelを開くとレイアウト崩れやマクロの無効化が発生する根本的な原因と、それを完全に解決するためのTeamsの設定手順、さらにマクロ(VBA)の代替となる最新機能「Officeスクリプト」に至るまで、徹底的に解説します。この記事を読めば、TeamsとExcelの連携に関するトラブルはすべて解決します。

目次

1. なぜTeams上でExcelを開くとレイアウトが崩れ、マクロが動かないのか?

結論から言うと、Teamsのチャットやチャネル内でファイルをクリックして開いたときに起動するExcelは、あなたが普段パソコンで使っている「デスクトップ版のExcelアプリ」ではありません。ブラウザ上で動作する軽量版である「Excel for the Web(Web版Excel)」を、Teamsの画面内に埋め込んで表示しているだけなのです。

Web版のExcelは、インターネット回線さえあればインストール不要で素早く開けるというメリットがある反面、動作を軽くするために多くの高度な機能が削ぎ落とされた「簡易バージョン」となっています。

そのため、デスクトップ版のExcelで作成された複雑なレイアウト、高度なグラフ、そしてVBA(マクロ)を含んだファイルをこの簡易バージョンで無理やり表示・実行しようとすると、システムが処理しきれずに「レイアウトの崩れ」や「機能の無効化」という形で不具合が表面化するのです。

特に、VBA(Visual Basic for Applications)はWindowsのOS環境(パソコン本体のシステム)に深く依存するプログラミング言語であるため、セキュリティと構造上の理由から、クラウド・ブラウザベースであるWeb版Excel(およびTeams内蔵Excel)では一切動作しない仕様になっています。

2. Teams内蔵Excel(Web版)で制限される主な機能一覧

では、具体的にどのような機能がTeams上で開いたときに崩れたり、機能しなくなったりするのでしょうか。Microsoftの公式ドキュメントに基づき、実務で影響が出やすい「サポートされていない機能」や「表示が異なる機能」をまとめました。

① VBA(マクロ)とActiveXコントロール

前述の通り、マクロを含むファイル(.xlsm)をTeams上で開くこと自体は可能ですが、マクロのコードを表示したり、実行したりすることはできません。シート上に配置された「マクロ実行ボタン」をクリックしても何も起きない、あるいはボタン自体が画像として表示されるだけになります。また、ActiveXコントロール(古い形式のチェックボックスやコンボボックス等)は表示すらされない場合があります。

② 印刷レイアウト(改ページプレビュー)

Teams上のExcelには「改ページプレビュー」という概念が存在しません。デスクトップ版で「ここで1ページに収める」と緻密に設定した印刷範囲や余白のレイアウトは、Teams上で見るとただの連続したセルの集まりとして表示され、全く違うレイアウトに見えてしまいます。これが「レイアウトが崩れた」と錯覚する最も多い原因です。

③ 図形(シェイプ)やテキストボックスの配置

デスクトップ版でセルに合わせて配置した図形やテキストボックス、SmartArtなどは、Teams上の簡易描画エンジンでは正確に位置合わせができず、数ミリから数センチずれて表示されることが多々あります。

④ パスワード保護されたファイル

ファイルを開くための暗号化パスワードが設定されているExcelファイルは、そもそもTeamsのプレビュー画面で開くことができず、エラーメッセージが表示されます。

⑤ 高度なデータ接続(Power Queryなど)

他のファイルや外部のデータベースから情報を引っ張ってくるPower Queryや、複雑なピボットテーブルの一部機能は、Teams上ではデータの「更新」ボタンを押すことができません。最新のデータを反映させるにはデスクトップアプリで開く必要があります。

⑥ レガシーなファイル形式

「.xls」や「.csv」などの古い形式、またはテキスト形式のファイルは、Teams上では正しく表形式で表示されない、あるいは文字化けを引き起こす原因となります。

3. 【根本解決】常に「デスクトップアプリ」で開くようにTeamsを設定する方法

この問題を根本から解決し、二度とレイアウト崩れやマクロの不具合に悩まされないようにするためには、Teams上でExcelファイルをクリックした際、自動的にパソコン本体に入っている「デスクトップ版のExcelアプリ」が起動するように設定を変更するのが最も確実で推奨される方法です。

現在主流となっている「新しいTeams(New Teams)」における設定手順は以下の通りです。

Teamsのファイルを開く既定の設定を変更する手順

  1. Teamsアプリを開き、画面右上にある「…(設定とその他)」をクリックします。
  2. 表示されたメニューから「設定」(歯車のアイコン)をクリックします。
  3. 設定画面の左側のメニューから「ファイルとリンク」を選択します。
  4. 「ファイルの開く設定」または「ファイルの環境設定」という項目にある「常にWord、PowerPoint、および Excel ファイルを開く」のプルダウンメニュー(ドロップダウンリスト)をクリックします。
  5. 選択肢の中から「デスクトップ アプリ」を選択します。
  6. 設定画面の右上にある「×」ボタンで画面を閉じます。(設定は自動的に保存されます)

この設定を行うことで、以降Teamsのチャットやチャネルで共有されたExcelファイルをクリックすると、Teamsの画面内ではなく、普段使い慣れているフル機能のExcelが別ウィンドウで立ち上がるようになります。もちろん、デスクトップアプリで開いても自動保存は機能しており、他メンバーとの共同編集も可能です。

※注意点:この設定は「自分自身のTeamsアプリ」にのみ適用されます。チームの他のメンバーの環境には影響しないため、他のメンバーも同じように困っている場合は、この設定方法を社内で共有することをお勧めします。

4. その都度「デスクトップアプリで開く」を選択する方法

「基本はTeams内で素早く確認したいけれど、マクロを実行するファイルや印刷レイアウトを確認したい時だけデスクトップ版で開きたい」という場合は、デフォルト設定は変更せずに、開くときにその都度手動で開き方を選択することも可能です。

チャットやチャネルの投稿から手動で開く手順

  1. 開きたいExcelファイルにマウスカーソルを合わせます。
  2. ファイル名の右側に表示される「…(その他のオプション)」をクリックします。
  3. メニューの中から「開く」にカーソルを合わせます。
  4. 右側に展開されるサブメニューから「アプリで開く」(または「デスクトップアプリで開く」)をクリックします。

すでにTeams内で開いてしまった画面から切り替える手順

誤ってクリックしてTeams内でファイルを開いてしまい、レイアウトが崩れていることに気づいた場合でも、わざわざ画面を閉じる必要はありません。

  1. Teams内で開いているExcelの画面上部(リボンの少し上、中央付近)にある「表示中」または「編集」というボタンの横にあるプルダウンを探します。
  2. その周辺にある「デスクトップ アプリで開く」というボタンをクリックします。
  3. 「ファイルを開いています…」というメッセージが出た後、パソコン本体のExcelアプリが立ち上がり、同じファイルが正常なレイアウトで表示されます。
  4. その後、Teams側の画面は「このファイルを閉じる」ボタンを押して閉じて構いません。

5. マクロ(VBA)が動かない問題の最新の解決策:Officeスクリプトへの移行

ここまでの対処法で「デスクトップアプリで開く」ことでVBAの問題は回避できます。しかし、近年ではMacユーザーの増加や、スマートフォン・タブレットからのアクセス、あるいはセキュリティの観点から「そもそもVBAの使用を社内で禁止する」といった流れが加速しています。

そこでMicrosoftが、Web版ExcelやTeams上でも動作する「VBAの後継」として力を入れているのが「Office スクリプト(Office Scripts)」です。

Officeスクリプトとは?

Officeスクリプトは、JavaScriptをベースにした「TypeScript」というプログラミング言語を使ってExcelの自動化を行う機能です。VBAが「パソコンのOS上で動く」のに対し、Officeスクリプトは「クラウド(Web)上で動く」ように設計されているため、Teams内臓のExcelやブラウザ版のExcelでもボタン一つでマクロ(自動化プログラム)を実行できるのが最大の特徴です。

さらに、Power AutomateというMicrosoftの自動化ツールと連携することで、「毎日朝9時に、Teamsの特定のチャネルに最新の売上データを抽出してメッセージを投稿する」といった、VBAでは難しかったクラウド間の自動化が容易に実現できます。

VBAとOfficeスクリプトのコード比較例

例えば、「アクティブなシートのA1セルに『売上報告』という文字を入力し、背景色を黄色にする」という簡単なプログラムを比較してみましょう。

【VBAの場合】(Teamsでは動かない)

Sub WriteReport()
    With ActiveSheet.Range("A1")
        .Value = "売上報告"
        .Interior.Color = vbYellow
    End With
End Sub

【Officeスクリプトの場合】(TeamsやWebでも動く)

function main(workbook: ExcelScript.Workbook) {
    // 現在のワークシートを取得
    let selectedSheet = workbook.getActiveWorksheet();
    // A1セルを取得
    let range = selectedSheet.getRange("A1");
    // 値と背景色を設定
    range.setValue("売上報告");
    range.getFormat().getFill().setColor("yellow");
}

もし社内で「Teams上で直接マクロボタンを押して業務を完了させたい」という強い要望がある場合は、既存のVBAをOfficeスクリプトに書き換える(移行する)ことを検討する時期に来ていると言えます。「自動化」タブにある「操作を記録」機能を使えば、VBAのマクロの記録と同じように、操作からコードを自動生成することも可能です。

6. チーム内でのファイル共有・運用のベストプラクティス

Teamsでのファイル共有において、無用なトラブルを防ぐための運用ルール(ベストプラクティス)をいくつか紹介します。

  • 「デスクトップアプリで開く」をチームの標準ルールにする:
    新入社員や異動してきたメンバーには、初期設定の段階でTeamsのファイル設定を「デスクトップアプリ」に変更するようマニュアル化しておくと、問い合わせ対応の手間が省けます。
  • VBAを含むファイル名には明記する:
    マクロ有効ブック(.xlsm)を共有する際は、ファイル名に「【マクロあり】売上集計.xlsm」などと記載し、チャットのメッセージにも「必ずデスクトップアプリで開いてマクロを実行してください」と一言添えるだけで、メンバーの混乱を防げます。
  • レイアウト確認用はPDF化する:
    印刷レイアウト通りに相手に見せたい見積書や請求書などは、Excel形式のまま送るのではなく、デスクトップアプリで「PDF形式」にしてからTeamsに投稿するのがビジネス上のマナーであり、最も確実なレイアウト崩れ防止策です。
  • 「シートビュー」を活用する:
    デスクトップアプリで開いて共同編集している際、誰かがフィルターをかけると全員の画面が変わってしまいます。これを防ぐため、「表示」タブの「シートビュー(新しいビュー)」機能を使い、自分だけのフィルター画面を作成するルールを徹底しましょう。

7. よくある質問(FAQ)

Q1. Teamsの設定で「デスクトップアプリ」が選べません。表示されていないのはなぜですか?

設定項目に「デスクトップアプリ」が存在しない場合、お使いのパソコンにMicrosoft 365のデスクトップ版Officeアプリが正しくインストールされていないか、ライセンスが「Web版のみ(Microsoft 365 Business Basicなど)」の契約になっている可能性があります。また、会社のIT管理者がセキュリティポリシーによってデスクトップアプリの使用を制限している場合もあります。社内の情報システム部門にご確認ください。

Q2. デスクトップアプリで開くと、他の人との「同時編集」ができなくなりますか?

いいえ、同時編集(共同編集)は可能です。Teamsからデスクトップアプリで開いた場合でも、ファイルの実体はクラウド(SharePointまたはOneDrive)上にあるため、画面左上の「自動保存」がオンになり、他の人が編集しているセルにはその人の名前のカーソルが表示され、リアルタイムに共同編集が行えます。

Q3. Teamsのスマホアプリからでもデスクトップアプリのように開けますか?

スマートフォンのTeamsアプリからExcelファイルを開くと、スマホにインストールされている「Excelモバイルアプリ」で開かれます。モバイルアプリはWeb版よりもさらに機能が制限されているため、マクロの実行などはできません。高度な処理は必ずパソコンから行う必要があります。

Q4. Macを使っていますが、設定方法は同じですか?

はい。Mac版のTeamsアプリでも、右上の「設定」>「ファイルとリンク」からファイルの開き方を「デスクトップアプリ」に変更する手順は全く同じです。Mac版のExcelが起動してファイルが開かれます。

8. まとめ

Teams上でExcelを開いた際に発生する「レイアウト崩れ」や「マクロが動かない」という現象は、Teams内で起動しているのが機能制限されたWeb版のExcelであることが原因です。

この問題を解決するためのポイントは以下の通りです。

  • Teamsの「設定」>「ファイルとリンク」から、ファイルの開き方を常に「デスクトップアプリ」に変更する。これが最も確実でストレスのない解決策です。
  • 設定を変更したくない場合は、ファイルの「…」メニューから「アプリで開く」を都度選択する。
  • 将来的にクラウドやTeams上で直接自動化を行いたい場合は、VBAから最新の「Officeスクリプト」への移行を検討する。
  • 印刷時のレイアウトを相手に正確に伝えたい場合は、PDFに変換してからTeamsに投稿する。

これらの仕組みを理解し、正しい設定を行うことで、Teamsの利便性を損なうことなく、Excelのフル機能を存分に活用した快適な業務環境を構築することができます。ぜひ今日から設定を見直し、チームのメンバーにも共有してみてください。