Case1:Cellsでぐるぐる回しながら取得する
Case2:get_Rangeでぐるぐる回しながら取得する
Case3:範囲のデータを1度に取得する
using System; using System.Diagnostics; using System.Reflection; using System.Runtime.InteropServices; using System.Windows.Forms; using Excel = Microsoft.Office.Interop.Excel; namespace ExcelTest { class Program { static void Main(string[] args) { Excel.Application xlApplication = null; Excel.Workbooks xlWorkbooks = null; Excel.Workbook xlWorkbook = null; Excel.Sheets xlSheets = null; Excel.Worksheet xlWorksheet = null; try { xlApplication = new Excel.Application(); xlApplication.Visible = true; xlWorkbooks = xlApplication.Workbooks; xlWorkbook = xlWorkbooks.Add(); xlSheets = xlWorkbook.Sheets; xlWorksheet = xlSheets[1]; Case1(xlWorksheet); Case2(xlWorksheet); Case3(xlWorksheet); xlWorkbooks.Close(); xlApplication.Quit(); } catch(Exception ex) { MessageBox.Show(ex.Message); } finally { if (xlSheets != null) { Marshal.FinalReleaseComObject(xlSheets); } if(xlWorkbook != null) { Marshal.FinalReleaseComObject(xlWorkbook); } if (xlWorkbooks != null) { Marshal.FinalReleaseComObject(xlWorkbooks); } if (xlApplication != null) { Marshal.FinalReleaseComObject(xlApplication); } } } static void Case1(Excel.Worksheet xlWorksheet) { Stopwatch sw = new Stopwatch(); sw.Start(); Excel.Range xlRange = null; for (int r = 1; r <= 100; r++) { for (int c = 1; c <= 10; c++) { xlRange = xlWorksheet.Cells[r, c]; Marshal.FinalReleaseComObject(xlRange); } } sw.Stop(); Console.WriteLine("[{0}]{1}", MethodBase.GetCurrentMethod().Name, sw.Elapsed); } static void Case2(Excel.Worksheet xlWorksheet) { Stopwatch sw = new Stopwatch(); sw.Start(); Excel.Range xlRange = null; string[] column = new string[]{ string.Empty, "A", "B", "C", "D", "E", "F", "G", "H", "I", "J"}; for (int r = 1; r <= 100; r++) { for (int c = 1; c <= 10; c++) { xlRange = xlWorksheet.get_Range(column[c] + r.ToString()); Marshal.FinalReleaseComObject(xlRange); } } sw.Stop(); Console.WriteLine("[{0}]{1}", MethodBase.GetCurrentMethod().Name, sw.Elapsed); } static void Case3(Excel.Worksheet xlWorksheet) { Stopwatch sw = new Stopwatch(); sw.Start(); object[,] cellData = new object[100, 10]; cellData = xlWorksheet.get_Range("A1", "J100").Value; sw.Stop(); Console.WriteLine("[{0}]{1}", MethodBase.GetCurrentMethod().Name, sw.Elapsed); } } }
[Case1]00:00:24.1975109 [Case2]00:00:06.7251560 [Case3]00:00:00.0383916
比較するまでもないよな。。。
0 件のコメント:
コメントを投稿