ExcelのようなMSオフィスのアプリケーションは、Visual Basic for Applicationsでプログラミングすることができます。高度なタスクのためにC#でMSオフィスをプログラムすることは可能ですか?C#でMSオフィスをプログラミングすることは可能ですか?
答えて
はい、そうです。 Visual Studio Tools for Officeを使用すると、アドインをC#、VB.NETなどで記述することができます.COM interopを使用してOfficeと通信します。
また、最近ではJavaScriptとおそらくサーバーエンドポイントのハイブリッドで、C#でもコード化できるOffice appsがあります。
間違いなく。あなたは無料でVisual Studio Community 2015をインストールすることができます。そして、(パスは変更になる場合があります)このフォルダに見て:
C:\プログラムファイルのMicrosoftのVisual Studio \(x86の)ことができますここからOffice \ PIA \ Office15
12.0 \ Visual Studioツール各OfficeアプリケーションのDLLを見つける。
たとえば、Microsoft.Office.Interop.Excel.dll
を実行すると、新しいC#プロジェクトを開始し、そのDLLをプロジェクト参照に追加します。
using Excel = Microsoft.Office.Interop.Excel;
その後は、このようなあなたのExcelアプリケーションを初期化することができます。
Excel.Application xlApp = new Excel.Application();
Excel.Workbook xlWorkbook = xlApp.Workbooks.Open(@"C:\path\file.xlsx");
Excel.Worksheet xlWorksheet = xlWorkbook.Sheets[1];
これらのチュートリアルの豊富さがご来店中です。 DoNotPerlsは基本的に開始するには良い場所です:
もう一つの大きな選択肢(と私はお勧め1)アドインエクスプレスを使用しています。 https://www.add-in-express.com
これらのツールセットは、VSTOまたはCOMアドインで可能な機能を大幅に拡張します。彼らのサポートは素晴らしく、サイトにはほぼすべてのOffice開発シナリオの例があります。
Excel-DNAは言うまでもありません。才能があり、非常に有益なチャップと良いコミュニティサポートによって書かれた驚くべき製品。無料で利用でき、Excelのカスタム機能、RTDサーバー、その他の機能を簡単に作成できます。
Excel-DNAは.NETをExcelに統合する独立したプロジェクトです。 Excel-DNAでは、C#、Visual Basic.NETまたはF#を使用してExcel用のネイティブ(.xll)アドインを作成し、高性能ユーザー定義関数(UDF)、カスタムリボンインターフェイスなどを提供できます。アドイン全体を、インストールや登録を必要としない単一の.xllファイルにパックすることができます。
カスタム関数を記述するのは、静的メソッドを作成し、コンパイルされたDLLまたは.csファイルに提供されたXLLファイルを含めるのと同じくらい簡単です。
Excelの場合、追加のアドインデプロイメントオーバーヘッドなしでライブのExcelセッションでC#を使用して、軽量ユーザー定義の関数とコマンドをインタラクティブに書くために、ESharperアドインを使用できます。
- 1. オブジェクト指向プログラミングにCUDA Cを使用することは可能ですか?
- 2. プログラミングで「平均値」を表すことは可能ですか?
- 3. 実行可能ファイルをMS-DOSプログラムに渡すことは可能ですか?
- 4. 別のプログラミング言語でセロリを使用することは可能ですか?
- 5. MS Access 2007でSHA512ダイジェストを使用することは可能ですか
- 6. msアクセスでMsysobjectsを変更することは可能ですか
- 7. C++でアプレットを使用することは可能ですか
- 8. Eigenをcで使用することは可能ですか?
- 9. cでシリアルポートクラスを使用することは可能ですか?
- 10. Cでオブジェクトメソッドをエミュレートすることは可能ですか?
- 11. MS Visual C#2008 Express EditionとIISでASP.NET MVCを開発することは可能ですか?
- 12. これはC++で可能ですか?
- 13. C#7.0でデコンストラクタをオーバーロードすることは可能ですか? C#7.0では
- 14. MSアクセスでレポートを組み合わせることは可能ですか?
- 15. C#.NET Winforms:Label.Autosizeをオーバーライドすることは可能ですか?
- 16. コードをアトミック(C#)にすることは可能ですか?
- 17. C++コードを象徴することは可能ですか?
- 18. C++クラスのテンプレートインスタンスをコンパイルすることは可能ですか?
- 19. c#app:JSONインターフェイスを実装することは可能ですか?
- 20. MS Access 2003レポートで次の結果を得ることは可能ですか? MS Access 2003で
- 21. msの見出しタイプ(または名前)をC#から見ることは可能ですか?
- 22. LaravelのMySQLにMS-SQLを参加させることは可能ですか
- 23. Turbo C++でPDFファイルを開くことは可能ですか?
- 24. vb.netやC#でアセンブリコードを書くことは可能ですか?
- 25. C/C++のGoインタフェースを模倣することは可能ですか?
- 26. 関数型プログラミングと自己コメントコード - これは本当に可能ですか?
- 27. C#(ASP.NET)でJSONクエリをプログラムで実行することは可能ですか?
- 28. PHPのC++バイナリを使用することは可能です
- 29. は、win32アプリケーションでactiveXコントロールを使用することは可能ですか?ことは可能であるが、
- 30. MSオフィスのホットキーを無効にする
私は、そこには2つの一般的な方向があると思います。まず、Excel(またはその他)内にいくつかの機能を追加するための一種のプラグインをプログラミングします。これは、例えば、パトリックが言ったように、VSTO。もう一つは、自分自身を凌駕するファイルを操作するプログラムです。これは、NPOI、またはそこにいくつかの他のライブラリの1つで行うことができます... –
NPOIは、MicrosoftのドキュメントのためのJava APIのようなものです(これは.net用です)? – Fsalad
NPOIは、Excel/WordファイルをC#アプリケーションから直接操作するためのクラス/メソッドを提供するライブラリです。 https://npoi.codeplex.com/をご覧ください –