ادغام چند گزارش استیمول سافت بصورت پی دی اف در یک فایل
سلام من جدولی بصورت زیر دارم.

اگر روی گزینه های مشخص شده کلیک بشه فایل گزارش اون دانلود میشه.
این گزارش رو در استیمول سافت طراحی کردم و کدها در کنترلر بصورت زیر هستند:
StiReport report = new StiReport();
var Report_eng_fa = _ProjectRepository.Report_eng_fa(PrjId).OrderBy(x =>x.c2).OrderBy(x=>x.NumberG);
report["prj_name"] = Mainproject.Mprj_name;
.
.
report["tbl_name"] = project.prj_tabluname;
List<IncludeKianPrintViewModel> myList = Report_eng_fa.ToList();
report.RegData("ds", myList);
return StiNetCoreReportResponse.ResponseAsWord2007(report);
و خروجی هم بصورت زیر :

تا اینجا مشکلی نیست اما من قصد دارم گزینه ای قرار بدم ک وقتی روی اون کلیک میشه بصورت خودکار فایل دو ردیف یا بیشتر که در جدول مشخص هست رو پشت سرهم در یک فایل پی دی اف دانلود کنه.
( بصورت معمول باید هر دفعه روی گزینه مشتری کلیک بشه و جداگانه دانلود میشه و میشه دو فایل یا بیشتر فایل پی دی اف)
اما من می خوام گزارش ها رو پشت سرهم در یک فایل پی دی اف دانلود کنه.
در نت سرچ زدم این لینک رو مطالعه کردم و کتابخانه اش رو هم نصب کردم اما در روش ذکر شده همانند کد زیر
pdfEditor.Concatenate("file1.pdf", "file2.pdf", "merged.pdf");
دو تا "نام فایل" که استرینگ هست با هم ترکیب میشه اما من نامی ندارم که با هم ترکیب بشن و یک راست روی گزینه ی مشتری که میزنم دانلود میشن.
لطفا راهنمایی بفرمایید که من با کدهایی ک قرار دادم چطور می تونم چند فایل پی دی اف رو ادغام کنم و همه ی گزارش ها رو پشت سرهم در یک فایل پی دی اف دانلود کنم؟؟
پاسخ هوش مصنوعی
برای ادغام چند گزارش استیمول سافت به یک فایل پی دی اف، شما نیاز دارید که ابتدا فایل های پی دی اف را به صورت موقت ایجاد کنید و سپس آن ها را با استفاده از کتابخانه ای مانند Aspose.PDF ادغام کنید. در زیر یک مثال از روند کار را ارایه می دهم:
// ابتدا متغیرهایی برای گزارش ها تعریف کنید
List reports = new List();
var selectedReports = GetSelectedReports(); // تابعی برای دریافت گزارش های انتخاب شده
// برای هر گزارش انتخاب شده، آن را تولید و به لیست گزارش ها اضافه کنید
foreach (var reportItem in selectedReports)
{
StiReport report = new StiReport();
// تنظیمات و داده های گزارش
report["prj_name"] = reportItem.PrjName;
report.RegData("ds", reportItem.DataList);
// ذخیره گزارش به صورت یک فایل موقت
string temporaryFilePath = Path.Combine(Path.GetTempPath(), $"{reportItem.Name}.pdf");
report.SaveToPdf(temporaryFilePath);
reports.Add(temporaryFilePath);
}
// حالا فایل های موقت را ادغام کنید
string mergedFilePath = Path.Combine(Path.GetTempPath(), "merged_report.pdf");
using (var pdfEditor = new PdfFileEditor())
{
pdfEditor.Concatenate(reports.ToArray(), mergedFilePath);
}
// در نهایت، فایل ادغام شده را به کاربر دانلود کنید
return StiNetCoreReportResponse.ResponseAsFile(mergedFilePath, "merged_report.pdf");
در این کد، ابتدا شناسایی می شود که کدام گزارش ها باید تولید شوند. سپس هر گزارش به صورت یک فایل PDF موقت ذخیره می شود و در نهایت همه فایل های موقت به یک فایل PDF نهایی ادغام می شوند. توجه داشته باشید که باید مسیر مناسب برای ذخیره فایل ها و اضافه کردن مدیریت خطا نیز در نظر گرفته شود.
- آموزش استفاده از پلاگین گردونه شانس در Asp.net core به همراه سورس
- نمایش متن به صورت فرمت شده در CkEditor
- آموزش استفاده از SignalR در Asp.net Core با مثال عملی
- ادغام چند گزارش استیمول سافت بصورت پی دی اف در یک فایل
- نحوه تغییر استایل کامپوننت select2 چگونه است ؟
- چگونه امنیت پروژه را در Asp.net Core افزایش دهیم ؟
- ارسال پارامتر در دستور window.open جی کویری
- ارسال پارامتر از طریق جاوااسکریپت با کلیک روی تگ a
- خطای 500 زمان اجرا شدن پروژه روی هاست
- کویری نویسی در استیمول سافت جهت فیلتر اطلاعات
- کار با CkEditor با قابلیت آپلود عکس
- خطا در ایجاد migration در Asp.net core
- تفاوت های Asp.net core و Asp.net mvc چیه؟
- دلیل اسپم شدن ایمیل های ارسالی از سرور
- نحوه لایه بندی پروژه Core و اضافه کردن به IIS
- ارسال ایمیل در Asp.net core
- آیا میشه در mvc core از کامپونت استفاده کرد
- آپلود فایل در Asp.net core چگونه است؟
- حذف کامل یک رکورد در جدول ریلیشن شده
- اشکال در آپلود فایل ویدیو در mvc core 2