نظرات مطالب
معرفی کتابخانه PdfReport
ممنون آقای نصیری. من با توجه به مقالات گذشته شما در زمینه iTextSharp یک کتابخانه کوچک برای کارهای خودم تهیه کرده بودم ولی محدودیت‌ها و مشکلات زیادی داشت. با توجه به اینکه کیفیت pdf‌های سایت شما به نظرم خیلی خوب هستن تصمیم داشتم از شما درباره نحوه ساخت اونها سوال کنم که خودتون زحمتشو کشیدید. قصد دارم با اجازه شما این کتابخانه را جایگزین کنم. باز هم از شما ممنونم
پاسخ به بازخورد‌های پروژه‌ها
هدر دو تکه
- عرض سلول‌ها را باید مشخص کنید و گرنه هر کدام نصف عرض کل را بر می‌دارند.
- هر سطر یا هر سلول یک جدول می‌تواند حاوی یک جدول جدید باشد.
- از نحوه‌ی تشکیل topTable و infoTable مطلب «تهیه‌ی کارت با فرمت PDF با استفاده از کتابخانه iTextSharp» ایده بگیرید.
- روش‌های دیگری هم برای تشکیل هدر وجود دارند؛ برای مثال استفاده از html.
پاسخ به بازخورد‌های پروژه‌ها
فونت نستعلیق
مشکل هم به اینجا بر می‌گرده که iTextSharp فعلا نمی‌تونه قسمت GSUB فونت‌های پیچیده رو آنالیز و استفاده کنه. نمونه همین مشکل رو هندی‌ها هم دارند (نمایش صحیح متون هندی بدون آنالیز GSUB فونت‌های آن‌ها، تقریبا بی‌معنا و غلط است).
اطلاعات بیشتر در اینجا
پاسخ به بازخورد‌های پروژه‌ها
سوال در مورد هدر
- بله. همانطور که در custom footer عمل شده در custom header عمل کنید. مثالش جزو مجموعه مثال‌های پروژه هست.
- در این مورد در پرسش‌های قبلی بحث شده. کمی جستجو کنید. fix weak characters هست متدش.
- بله. باید با canvas کار کنید در iTextSharp. این مورد با شیء PdfWriter و ContentByte آن شروع می‌شود.
پاسخ به بازخورد‌های پروژه‌ها
کندی ایجاد فایل pdf
کتابخانه iTextSharp نزدیک به 3 و نیم مگ حجم دارد. JIT در همان آغاز کار برنامه سعی در کامپایل کل این کتابخانه نخواهد کرد چون سرعت startup را کاهش می‌دهد. این مساله موکول خواهد شد به زمان تهیه اولین گزارش. به همین جهت این زمان نسبتا زیاد به نظر می‌رسد اما برای دفعات بعدی، چون نتیجه کش شده است، حاصل کار بسیار سریع خواهد بود.
پاسخ به بازخورد‌های پروژه‌ها
ایجاد یک گزارش تمام صفحه از چارت بدون رکورد
لطفا به این دو مطلب مراجعه نمائید:
- قرار دادن جدول و چارت با هم : «قرار دادن نمودارهای MS Chart در گزارشات PdfReport»
- فقط قرار دادن چارت در فایل PDF :
 «Microsoft Chart Controls to PDF with iTextSharp and ASP.NET MVC »

بازخوردهای پروژه‌ها
Report Viewer

سلام جناب آقای نصیری

با تشکر از زحمتی که کشیدید. بسیار پروژه ارزشمندی هست pdfreport

موقعی که شما درباره itextsharp مطلب مینوشتید به این موضوع اشاره کردید که این گزارشات هم به نوعی html هستند .آیا این مقدور هست که متدی برای تبدیل این pdf به صورت html هم وجود داشته باشد تا بتوانیم یک preview به کاربر نشان بدهیم؟

با تشکر

بازخوردهای پروژه‌ها
تعریف جدول در openOffice , و پرکردن فیلدهای آن در itextSharp
سلام اقای نصیری ممنونم از مطالب مفید سایتتون
اقای نصیری آیا امکان این وجود داره که من در برنامه openOffice  یه قالب تعریف کنم که جدول داشته باشه و بعد بیام با itextSharp  اون جدول رو به صورت داینامیک با داده‌های datagrid  پرکنم؟
ممنونم از لطفتون
فایل‌های پروژه‌ها
PdfRpt-2.3.rar
- Fixed printSummary to show Unicode RTL data.
- Improved CellCreated event to work with summary rows. See 'AccountingBalanceColumnPdfReport.cs' sample for more info.
- Updated the project to use iTextSharp 5.4.5.
مطالب
چگونه یک عبارت sql را فرمت شده نمایش دهیم؟
در مورد کتابخانه‌ی SQLDom مطالبی را پیشتر در این سایت مطالعه کرده‌اید (^ و ^). یکی دیگر از کاربردهای آن، فرمت عبارات SQL است. برای مثال تبدیل عبارتی مانند
SELECT * FROM tb1 WHERE x1 = '12';
به نمونه‌ی فرمت شده‌ی آن:
SELECT *
FROM tb1
WHERE x1 = '12';
برای اینکار می‌توان از کلاس ذیل کمک گرفت:
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using Microsoft.SqlServer.TransactSql.ScriptDom;
 
namespace SqlDomAnalyzer.Core
{
    public static class PrettyPrintTSql
    {
        public static string FormatTSql(string tSql)
        {
            IList<ParseError> errors;
            TSqlScript sqlFragment;
            using (var reader = new StringReader(tSql))
            {
                var parser = new TSql120Parser(initialQuotedIdentifiers: true);
                sqlFragment = (TSqlScript)parser.Parse(reader, out errors);
            }
 
            if (errors != null && errors.Any())
            {
                var sb = new StringBuilder();
                foreach (var error in errors)
                    sb.AppendLine(error.Message);
 
                throw new InvalidOperationException(sb.ToString());
            }
 
            var sql110ScriptGenerator = new Sql120ScriptGenerator(new SqlScriptGeneratorOptions
            {
                SqlVersion = SqlVersion.Sql120
            });
            string finalScript;
            sql110ScriptGenerator.GenerateScript(sqlFragment, out  finalScript);
            return finalScript;
        }
    }
}
در اینجا ابتدا عبارت SQL ورودی Parse شده و سپس به کتابخانه‌ی تولید اسکریپت ScriptDom ارسال می‌شود. خروجی آن، یک خروجی فرمت شده‌است.

نکته‌ی جالب دیگری که در اینجا وجود دارد، تهیه‌ی یک خروجی همواره یک شکل است. برای نمونه سه عبارت SQL زیر را در نظر بگیرید:
SELECT * from tb1 WHERE x1 = '12';
SELECT * from tb1 where x1 = '12';
select * from tb1 WHERE x1 = '12';
در اینجا در عبارت اول، from با حروف کوچک نمایش داده شده‌است. در عبارت دوم، where نیز با حروف کوچک نمایش داده شده‌است و در عبارت سوم اینکار در مورد select نیز تکرار شده‌است.
در هر سه حالت یا هر حالت قابل تصور دیگری، خروجی SQL فرمت شده‌ی حاصل یک چنین شکلی را دارد:
SELECT *
FROM tb1
WHERE x1 = '12';

موارد کاربرد آن؟
علاوه بر نمایش زیبای SQL فرمت نشده، احتمالا برنامه‌های Profiler ایی را دیده‌اید که عنوان می‌کنند قادرند عبارات SQL همانند را تشخیص دهند (جهت یافتن Lazy loading اشتباه). یک چنین خروجی یکسانی، قابلیت تهیه Hash عبارات SQL دریافتی را میسر می‌کند؛ چون دیگر اینبار مهم نیست که اجزای تشکیل دهنده‌ی یک عبارت SQL با حروف بزرگ هستند یا کوچک و فاصله‌ی بین آن‌ها چقدر است و آیا در این بین خطوط جدیدی نیز وجود دارند و امثال آن. خروجی نهایی نرمال شده‌ی توسط Sql120ScriptGenerator همواره یک شکل است. از این دو قابلیت در برنامه‌ی DNTProfiler استفاده شده‌است.