質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Q&A

解決済

3回答

5062閲覧

C#で、エクセルファイルをアクセス方法について教えてください

suban

総合スコア28

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

0グッド

0クリップ

投稿2016/12/11 05:06

C#で、エクセルファイルをアクセスしようとしております
下記のサイトを、参考にさせて頂きアクセスのプログラムを
作成しようとしておりますが、ビルドをかけると下記のエラーが
発生します。対処の方法をご教示いただけないでしょうか

Applicationの箇所が赤アンダバーがついており、エラー内容は
「エラー CS0104 'Application' は、'Microsoft.Office.Interop.Excel.Application' と 'System.Windows.Forms.Application' 間のあいまいな参照です。」

参考にしたサイトはこちらです
http://qiita.com/kyama0922/items/f0c6449d8734889d1e83

using System; using System.Collections.Generic; using System.Linq; using System.Threading.Tasks; using System.Runtime.InteropServices; using Microsoft.Office.Interop.Excel; using System.Windows.Forms; namespace EXCEL_TEST3 { static class Program { /// <summary> /// アプリケーションのメイン エントリ ポイントです。 /// </summary> [STAThread] static void Main() { Application.EnableVisualStyles(); Application.SetCompatibleTextRenderingDefault(false); Application.Run(new Form1()); Microsoft.Office.Interop.Excel.Application ExcelApp = new Microsoft.Office.Interop.Excel.Application(); //エクセルを非表示 ExcelApp.Visible = false;

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

C#でエクセルに対する操作には、C#用のコンポーネントSpire.XLS for .NETをおすすめします。Visual Studioの参照にこのコンポーネントを追加して、そしてExcelの作成、読み取り、編集、印刷など様々な操作ができるようになります。エクセルファイルにアクセスするのもサポートされています。無料版のダウンロード先はこちらです、また色んなチュートリアルと記事もありますから、ぜひ見てください。

投稿2022/01/07 03:58

yamausag1

総合スコア30

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Zuishin

2022/01/07 04:08

またお前か。 こいつの回答は全部同じ有料のクソライブラリの宣伝。
guest

0

Excel云々とはとりあえず関係ないC#の文法の問題だと思います。先頭にあるusingはクラス名を参照する際にnamespaceのフルネームを一々指定しなくてよくするためのものですが、

c#

1using a.b; 2using c.d; 3 4... 5 ClassA a;

などと書いた場合、コンパイラーはクラス名ClassAが同一のnamespaceに書いてなければusingで指定されたいずれかのnamespaceの中から探してくれます。ところがa.b.ClassAとc.d.ClassAの両方がpublicなクラスとして存在しているとClassAという指定だけではどちらのクラスを参照しているのかをコンパイラーが決定できません。エラーはそういうことをいっています。「あいまい」というのはそういう意味です。

ご質問のコードにあるApplicationはフォームアプリケーションを作成した際にVisual Stuidioが自動生成したものですが、実際にはSystem.Windows.Forms.Applicationを意味します。自動生成コードでフルネームになっていないのは「Applicationというクラス名が存在しているようなnamespaceをユーザーがimportするようなことはレアケースだろうし、一々フルネームで生成するのは見ずらいから」という理由だと思います。

対処方法については

  1. 自動生成されたApplicationというクラス名を全てフルネームに置き換える

とりあえずは問題解消できますが「自動生成されたソースをこの理由で書き換える」のは個人的には筋がよくないと感じます。

  1. 同じ名前のクラスが含まれるimportをしない

using Microsoft.Office.Interop.Excel;を削除し、そのnamespace下の全クラスはフルネームで記載する方法です。名前が長ったらしくなるのでソースがみずらくなりますがそういったクラス数が少なければ許容できることもあるかも知れません。

  1. 同じ名前のクラスが含まれるimportがあるならモジュール(ソース)を分離する

Excelをアクセスするモジュールは別のソースに記述する方がすっきりします。当然ながらそちらのソースではSystem.Windows.Formsにアクセスしないことにして「Excelを操作することに特化した機能」のみ実装します。

投稿2016/12/11 05:37

編集2016/12/11 05:39
KSwordOfHaste

総合スコア18394

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

suban

2016/12/11 06:38

ご指摘のとおりです。 C#の文法の問題がまだよくわかっていないです。 namespaceの意味もわかっていなかったのですが 誠に、ありがとうございます。
guest

0

ベストアンサー

Microsoft.Office.Interop.ExcelとSystem.Windows.Forms両方にApplicationとクラスが存在するため
どっちらのApplicationクラスを使用すればよいか不明なためエラーになっています。

下記のようにApplicationクラスを使用している部分は、明示的に名前空間を指定するとよいです。

C#

1Application.EnableVisualStyles(); 2Application.SetCompatibleTextRenderingDefault(false); 3Application.Run(new Form1()); 4 ↓(変更) 5System.Windows.Forms.Application.EnableVisualStyles(); 6System.Windows.Forms.Application.SetCompatibleTextRenderingDefault(false); 7System.Windows.Forms.Application.Run(new Form1());

投稿2016/12/11 05:22

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

suban

2016/12/11 06:40 編集

ありがとうございます。C#の文法の問題が まだ、わかっていませんでした。 ご教示頂きありがとうございます。 エラーがなくなる事を確認いたしました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問