نمایش نتایج 1 تا 6 از 6

نام تاپیک: سوال در مورد انتقال اطلاعات به اکسل

  1. #1

    Question سوال در مورد انتقال اطلاعات به اکسل

    با سلام

    من برای انتقال اطلاعات از dbgrid به اکسل از کامپوننت SmExport استفاده میکنم . من حدود 600.000 رکورد دارم و میخواهم آن را به اکسل انتقال دهم ولی مدت زمان انتقال به اکسل بالای 10 ساعت طول میکشه . برای رفع این مشکل چه کاری بایستی انجام دهم . چه آیتمی را بایستی در کامپوننت ExportToExcell تنظیم کنم تا مدت زمان انتقال کاهش یابد

    با تشکر

  2. #2
    کاربر دائمی آواتار ROSTAM2
    تاریخ عضویت
    اسفند 1390
    محل زندگی
    فارس
    پست
    2,002

    نقل قول: سوال در مورد انتقال اطلاعات به اکسل

    نقل قول نوشته شده توسط سیروس مقصودی مشاهده تاپیک
    با سلام

    من برای انتقال اطلاعات از dbgrid به اکسل از کامپوننت SmExport استفاده میکنم . من حدود 600.000 رکورد دارم و میخواهم آن را به اکسل انتقال دهم ولی مدت زمان انتقال به اکسل بالای 10 ساعت طول میکشه . برای رفع این مشکل چه کاری بایستی انجام دهم . چه آیتمی را بایستی در کامپوننت ExportToExcell تنظیم کنم تا مدت زمان انتقال کاهش یابد

    با تشکر
    سلام
    دیتابیست چیه؟

    از کدهای ایجاد فایل اکسل و خود نرافزار اکسل می شه کمک گرفت:

    مثلا این کد برای DELPHI هست که از هوش مصنوعی COPILOT گرفته شد:


    uses
    ComObj;


    procedure CreateExcelFile;
    var
    ExcelApp, WorkBook, WorkSheet: Variant;
    begin
    try
    // ایجاد یک نمونه از Excel
    ExcelApp := CreateOleObject('Excel.Application');
    ExcelApp.Visible := False; // عدم نمایش Excel هنگام اجرا


    // افزودن یک Workbook
    WorkBook := ExcelApp.Workbooks.Add;
    WorkSheet := WorkBook.Worksheets[1];


    // افزودن داده به سلول‌های Excel
    WorkSheet.Cells[1, 1] := 'ستون 1';
    WorkSheet.Cells[1, 2] := 'ستون 2';
    WorkSheet.Cells[2, 1] := 'داده 1';
    WorkSheet.Cells[2, 2] := 'داده 2';


    // ذخیره فایل Excel
    WorkBook.SaveAs('C:\Users\YourUsername\Desktop\MyE xcelFile.xlsx');
    WorkBook.Close;


    ShowMessage('فایل Excel با موفقیت ایجاد شد!');
    except
    on E: Exception do
    ShowMessage('خطا: ' + E.Message);
    end;


    // آزاد کردن منابع
    ExcelApp.Quit;
    ExcelApp := Unassigned;
    end;




    در مورد سرعت عملکردش دیگه چیزی نمی دونم.

  3. #3

    نقل قول: سوال در مورد انتقال اطلاعات به اکسل

    سلام
    دیتابیسم SqlServer هستش
    آیا میشه چند ستون رو Merg کرد و یا ستون رو رنگی کرد ؟

  4. #4
    کاربر دائمی آواتار ROSTAM2
    تاریخ عضویت
    اسفند 1390
    محل زندگی
    فارس
    پست
    2,002

    نقل قول: سوال در مورد انتقال اطلاعات به اکسل

    نقل قول نوشته شده توسط سیروس مقصودی مشاهده تاپیک
    سلام
    دیتابیسم SqlServer هستش
    آیا میشه چند ستون رو Merg کرد و یا ستون رو رنگی کرد ؟
    همه تنظیماتی که می شه در محیط اکسل انجام داد در کدنوبسی هم می شه انجام داد... در مورد ویندوز 10 نمی دونم چون من ویندوز 10 رو آپدیت نکردم اما احتملا مثل ویندوز 11 اگه آپدیت بشه copilot می تونه کمک خوبی برای رسیدن به جواب این سوالها باشه...

    پاسخ COPILOT:

    Merg کردن خانه ها در اکسل از طریق کدنویسی DELPHI

    برای ترکیب یا Merg کردن سلول‌ها در اکسل با استفاده از زبان برنامه‌نویسی Delphi، می‌توانید از کتابخانه‌هایی مانند ComObj استفاده کنید تا به قابلیت‌های اکسل دسترسی پیدا کنید. در ادامه نمونه کدی آمده است که می‌تواند شما را در این مسیر راهنمایی کند:




    uses
    ComObj;


    procedure MergeCellsInExcel;
    var
    ExcelApp, Workbook, Worksheet, Range: Variant;
    begin
    // ایجاد نمونه‌ای از اکسل
    ExcelApp := CreateOleObject('Excel.Application');
    try
    ExcelApp.Visible := True; // تنظیم نمایش اکسل


    // ایجاد یک ورک‌بوک جدید
    Workbook := ExcelApp.Workbooks.Add;
    Worksheet := Workbook.Worksheets[1];


    // تنظیم داده‌ها در سلول‌ها
    Worksheet.Cells[1, 1].Value := 'Hello';
    Worksheet.Cells[1, 2].Value := 'World';


    // انتخاب رنجی از سلول‌ها برای ترکیب
    Range := Worksheet.Range['A1', 'B1'];
    Range.Merge(True); // ترکیب سلول‌ها


    // پیام در صورت موفقیت
    ShowMessage('Cells merged successfully!');
    finally
    // آزادسازی منابع
    ExcelApp := Unassigned;
    end;
    end;


    در مورد ستون ها چی؟

    برای ترکیب یا Merge کردن ستون‌ها در اکسل با Delphi، روند مشابهی داریم؛ اما به جای سلول‌های افقی، باید یک بازه عمودی را انتخاب کنید. در اینجا کد به‌روزرسانی‌شده برای ترکیب ستون‌ها آورده شده است:




    uses
    ComObj;


    procedure MergeColumnsInExcel;
    var
    ExcelApp, Workbook, Worksheet, Range: Variant;
    begin
    // ایجاد نمونه‌ای از اکسل
    ExcelApp := CreateOleObject('Excel.Application');
    try
    ExcelApp.Visible := True; // تنظیم نمایش اکسل


    // ایجاد یک ورک‌بوک جدید
    Workbook := ExcelApp.Workbooks.Add;
    Worksheet := Workbook.Worksheets[1];


    // تنظیم داده‌ها در سلول‌ها
    Worksheet.Cells[1, 1].Value := 'Hello';
    Worksheet.Cells[2, 1].Value := 'World';


    // انتخاب رنجی از سلول‌ها برای ترکیب
    Range := Worksheet.Range['A1', 'A2']; // بازه عمودی
    Range.Merge(True); // ترکیب سلول‌ها در ستون


    // پیام در صورت موفقیت
    ShowMessage('Columns merged successfully!');
    finally
    // آزادسازی منابع
    ExcelApp := Unassigned;
    end;
    end;



  5. #5

    نقل قول: سوال در مورد انتقال اطلاعات به اکسل

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

  6. #6
    کاربر دائمی آواتار ROSTAM2
    تاریخ عضویت
    اسفند 1390
    محل زندگی
    فارس
    پست
    2,002

    نقل قول: سوال در مورد انتقال اطلاعات به اکسل

    نقل قول نوشته شده توسط سیروس مقصودی مشاهده تاپیک
    خیلی ممنون مشکلم حل شد .
    نحوه رنگی نمودن و تغییر فونت حروف هم چنین چیزی است در مورد رنگ و فونت جستجو کردم ولی چیزی پیدا نکردم
    تغییر Style و زنگ و فونت خانه های Excel در Delphi?

    برای تغییر استایل، رنگ و فونت خانه‌های Excel در Delphi، می‌توانید از کتابخانه‌هایی مانند Excel Automation یا OLE Automation استفاده کنید. این کتابخانه‌ها به شما امکان می‌دهند که از طریق کدنویسی، تغییرات مورد نظر را اعمال کنید. در زیر یک نمونه کد ساده آورده شده است:




    uses
    ComObj;


    var
    ExcelApp, Workbook, Worksheet: Variant;
    begin
    // ایجاد یک نمونه از اکسل
    ExcelApp := CreateOleObject('Excel.Application');
    ExcelApp.Visible := True; // نمایش اکسل


    // ایجاد یک ورک‌بوک جدید
    Workbook := ExcelApp.Workbooks.Add;
    Worksheet := Workbook.Worksheets[1];


    // تغییر فونت و رنگ یک سلول
    Worksheet.Cells[1, 1].Value := 'Hello, Excel!';
    Worksheet.Cells[1, 1].Font.Name := 'Arial';
    Worksheet.Cells[1, 1].Font.Size := 14;
    Worksheet.Cells[1, 1].Font.Color := clRed; // رنگ قرمز
    Worksheet.Cells[1, 1].Interior.Color := $00FF00; // پس‌زمینه سبز


    // ذخیره فایل و بستن اکسل
    Workbook.SaveAs('C:\MyExcelFile.xlsx');
    ExcelApp.Quit;
    end;



تاپیک های مشابه

  1. حرفه ای: دانلود سورس تابلوی تبلیغاتی Led و سورس office 2007
    نوشته شده توسط farboodj1375 در بخش برنامه نویسی در 6 VB
    پاسخ: 8
    آخرین پست: شنبه 28 خرداد 1390, 11:12 صبح
  2. پاسخ: 9
    آخرین پست: یک شنبه 01 خرداد 1390, 19:11 عصر

قوانین ایجاد تاپیک در تالار

  • شما نمی توانید تاپیک جدید ایجاد کنید
  • شما نمی توانید به تاپیک ها پاسخ دهید
  • شما نمی توانید ضمیمه ارسال کنید
  • شما نمی توانید پاسخ هایتان را ویرایش کنید
  •