1

次のASP.net/iTextSharpコードを使用して、HTMLファイルの内容をPDFに解析し、応答ストリームにダンプします。

Response.Clear();
Response.ContentType = "application/pdf";
using (Document doc = new Document())
{
    PdfWriter writer = PdfWriter.GetInstance(doc, Response.OutputStream);
    doc.Open();
    using (TextReader reader = File.OpenText(Server.MapPath("~/Test.htm")))
    {
        XMLWorkerHelper.GetInstance().ParseXHtml(writer, doc, reader);
    }
    doc.Close();
}
Response.End();

これは機能しますが、結果のPDFは元のHTMLページのようなスタイルにはなりません。手始めに、組み込みのcssパーサーは、直接タグのスタイルとクラスでのみ機能するように見えます(:のような連鎖はありませんthead th { background-color:#999; })。

第二に、国境はオール・オア・ナッシングの取引であるように思われます。border-top、border-bottomなどの概念はなく、border-collapseは隣接するセルの境界を折りたたむことがないため、境界は必要な2倍の厚さになります。

最後に、テーブルをドキュメントの左側または右側に配置する方法がわかりません。常に中央に配置されます。text-alignを使用してdivでラップし、align属性を設定し、text-alignをテーブルに直接設定してみました。それを理解することはできませんか?

これが、概念実証として使用しようとしているデモドキュメントです。

<!DOCTYPE html>
<html>
<head>
    <title>This is the title</title>
    <meta name="description" content="This is the description" />
    <meta name="keywords" content="abc, 123, xyz" />
    <style type="text/css">
        body { font-family:Arial, Verdana, Sans-Serif; font-size:9pt; }
        .dataGrid { font-family:Arial, Verdana, Sans-Serif; font-size:9pt; border-collapse: collapse; border:1px solid #000; width:80%; margin:0; text-align:left; }
        th { padding:3px 4px; font-weight:bold; border:1px solid #000; }
        td { padding:3px 4px; border:1px solid #000; }
        .head { border-bottom:2px solid #000; background-color:#9BBA1F; font-weight:bold; }
        .odd { background-color:#fff; }
        .even { background-color:#D6EB87; }
        .foot { border-top:2px solid #000; background-color:#BAB0C4; font-weight:bold; }
        h1 { font-size:14pt; color:#FFA200; text-align:center; }
        .right { text-align:right; }
        .center { text-align:center; }
        .left { text-align:left; }
    </style>
</head>
<body>
    <h1>Sample Document</h1>

    <div style="text-align:left;">
    <table class="dataGrid" align="left">
        <thead>
            <tr class="head">
                <th width="70%">Name</th>
                <th width="15%" class="center">Qty</th>
                <th width="15%" class="center">Price</th>
            </tr>
        </thead>
        <tbody>
            <tr class="odd">
                <td>ABC</td>
                <td class="center">2</td>
                <td class="right">$5.00</td>
            </tr>
            <tr class="even">
                <td>XYZ</td>
                <td class="center">1</td>
                <td class="right">$10.00</td>
            </tr>
            <tr class="odd">
                <td>123</td>
                <td class="center">3</td>
                <td class="right">$2.00</td>
            </tr>
            <tr class="even">
                <td>789</td>
                <td class="center">1</td>
                <td class="right">$4.00</td>
            </tr>
        </tbody>
        <tfoot>
            <tr class="foot">
                <td class="right">Totals</td>
                <td class="center">7</td>
                <td class="right">$30.00</td>
            </tr>
        </tfoot>
    </table>
    </div>
</body>
</html>
4

1 に答える 1

1

これにたくさんの時間を費やした後、私はそれを正しく動作させることができませんでした。そのため、私は別のツールwkHtmlToPdfに切り替えることになりました。Nugetで利用可能なCodaxyラッパークラスを使用して呼び出しを作成しましたが、iTextSharpで見たよりもはるかに優れた結果が得られています。主にCSSセレクターを理解し、画像やリンクなどを自動的に処理します。

于 2012-09-27T13:01:31.770 に答える