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

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

ただいまの
回答率

90.33%

  • C#

    7709questions

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

  • Windows

    1540questions

    Windowsは、マイクロソフト社が開発したオペレーティングシステムです。当初は、MS-DOSに変わるOSとして開発されました。 GUIを採用し、主にインテル系のCPUを搭載したコンピューターで動作します。Windows系OSのシェアは、90%を超えるといわれています。 パソコン用以外に、POSシステムやスマートフォンなどの携帯端末用、サーバ用のOSもあります。

  • 印刷

    20questions

    印刷とは、インキを用いて紙などの被印刷物に機械的に複製することを指します。現在は紙などの2次元の媒体だけでなく、3次元の曲面にも直接印刷する技術など様々な開発が進んでいます。

C#での帳票印刷ライブラリ(無償のもの)はありませんでしょうか?

解決済

回答 6

投稿

  • 評価
  • クリップ 0
  • VIEW 3,638

gysnet

score 7

皆様、gysnetと申します。
どうぞよろしくお願い致します。
アドバイスいただけたら幸いです。

前提・実現したいこと

Windows10のPC上で動くC#(Visual Studio 2012)アプリケーションを
開発しようとしています。
DBはAccessです(ちょっとヘンテコな環境なのですが…)。
C#での帳票印刷ライブラリ(有償のもので言うと、Active Reportのようなもの)の中で無償で使えるものがありましたら、ご教授いただけませんでしょうか?
皆様のご実績の中でオススメとかありましたらよろしくお願い致します。

補足情報(言語/FW/ツール等のバージョンなど)

PDFに出力するようなものとかでも構いません。色々情報を得ることができたらと考えております。「こんなのはどう?」みたいなものがあればコメントいただきたいです。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 6

checkベストアンサー

+1

複雑なことを求めないなら
Micosoft Report
または、そのサーバ版の
SQL Server Reporting Services
がお勧めです。

余談ですが、C# から Access のファイルへ接続したり、編集したりするのはとても大変です。
64-32bit、データプロバイダのインストール、Officeのバージョン違い、Visual Studioのサーバエクスプローラで直接いじれないなどなど…
特別、やむにやまれぬ事情がない限り
SQL Server Express
または
SQL Server 2016 Express LocalDB
を使うほうが簡単です。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/03/25 23:32

    ありがとうございます。今回は、Microsoft Reportを採用致しました。
    BAにさせていただきます。

    キャンセル

0

MSAccessが使えるなら、dll経由でAccessの帳票をPDFプリンタに印刷させることができるはずです。

具体的なコードは知りません。(ゴメンなさい)

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/03/04 13:44

    iwamoto様、ありがとうございます。参考にさせていただきます。

    キャンセル

0

無料となると選択肢が狭まるので要件との兼ね合いで長所短所を検討して選択することになります。
それこそ「帳票印刷 無料」で検索して色々見られたら良いのではないかと思います。

Crystal Report や Microsoft Report ではダメだと言うなら、なぜそれがダメなのかを書かなければ勧めようがないでしょう。

他には Excel に出力されている方もおられますし、自分で描画するという選択肢もあります。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/03/04 15:16

    Zuishin様、ご回答ありがとうございます。検索キーワード試してみます。

    キャンセル

  • 2017/03/04 15:59

    一例ですよ。

    キャンセル

0

誰も書いていないので..
本末転倒かもしれませんが、こういう系にはちゃんとお金を払ったほうがいいです
自分の手間賃はタダで、自分の手間は無限に掛けられるって環境なら別にいいですけど、仕事なら人的コスト、時間的制約等を勘案すると結局お金を払った方が安くつきます
「神Excel」ではないですが、こと帳票に関しては日本で求められることが超絶ガラパゴスな内容が多いので..
それらのお悩みごとが日本でそこそこメジャーなものなら、プロパティ1つ設定するとかメソッド1つ呼ぶだけで、一発解決なんてこともありますし
やっぱりお金を取るものは伊達に取ってないですよ
もちろんスカな製品もありますが(苦笑

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/03/25 23:31

    ご指摘の通りです。元々は有償のものを提供する予定でしたが、要求元からのご要望が無償であったため、
    やむを得ずそうしました。有償版が一番いいです!

    キャンセル

0

ExcelでFormatを作成し、
Excelに対しデータをプログラムより書き込んだらいかがでしょう。

書式の設定等はExcel側で変更できますし、
ClosedXMLなどを用いるとExcelがインストールされていない環境でも動作できます。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/03/26 00:11

    ClosedXMLを一部採用させていただきました。ありがとうございます。

    キャンセル

0

gysnet さん、こんにちは。

ライブラリではなくAccessそのものを使用してもよいのでしたら、COMオブジェクト経由(Access.Application)で、Access のレポートを印刷されてはいかがでしょう?

Microsoft MSDN に Visual C# を使用して Microsoft Access を自動化する方法 と題された、ずばりのページがあります。
「Access レポートの印刷や印刷プレビュー」の項目が参考になると思います。

using Microsoft.Office.Interop.Access;

// ...

Access.Application oAccess = null;
oAccess = new Access.ApplicationClass();
// または
// var oAccess = CreateObject("Access.Application") as Access.Application;

oAccess.OpenCurrentDatabase(
   "c:\\mydb.mdb",
   true
   );

// ...

Excel をふくめ Office ソフトの COM オブジェクトを使用することで、マクロで操作できることなら基本的にほぼできますよ。

テスト用にマクロで作成してみて、それを C# に移植する方法が簡単かと思います。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/03/26 00:12

    ありがとうございます。COMを一部使用致しました。

    キャンセル

同じタグがついた質問を見る

  • C#

    7709questions

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

  • Windows

    1540questions

    Windowsは、マイクロソフト社が開発したオペレーティングシステムです。当初は、MS-DOSに変わるOSとして開発されました。 GUIを採用し、主にインテル系のCPUを搭載したコンピューターで動作します。Windows系OSのシェアは、90%を超えるといわれています。 パソコン用以外に、POSシステムやスマートフォンなどの携帯端末用、サーバ用のOSもあります。

  • 印刷

    20questions

    印刷とは、インキを用いて紙などの被印刷物に機械的に複製することを指します。現在は紙などの2次元の媒体だけでなく、3次元の曲面にも直接印刷する技術など様々な開発が進んでいます。