У меня есть консольное приложение С#, которому требуется разделить большой Excel на несколько файлов Excel на основе количества строк. В приведенном ниже коде показан исходный файл только с 51 строкой (включая строки столбца заголовка), но окончательный исходный файл будет содержать более 100 000 строк.
Код пытается пропустить самую первую строку (заголовок), а затем должен копировать строки со 2 по 11 и т. д. У меня в целевых файлах установлено только 10 строк в файле, чтобы ускорить разработку.
Вопрос Итак, как мне скопировать строки со 2 по 11 и последующие 10 строк из исходного файла Excel и вставить в несколько целевых файлов Excel, чтобы в каждом из целевых файлов было по 10 строк? ?
Вот почти недавно написанный код. Он основан на копировании определенного диапазона ячеек Excel с одного листа на другой лист и https://social.msdn.microsoft.com/Forums/vstudio/en-US/afd01976-63d0-4f96-9ba4-e3e2b6cf8d55/excel-with-c-how-to-specify-a-range-?forum=vsto
Теперь я могу написать 5 файлов Excel. Но в первом файле 9 строк (начиная со строки 2), в то время как во втором файле всего 3 строки, начиная с строки 10, в третьем файле 13 строк, начиная, опять же, с строки 10; последние два файла содержат все больше строк, начиная с строки 10.
Значит, что-то не так с моим For Loop
? Или как я выбираю ranges
?
string startPath = System.IO.Path.GetDirectoryName(System.Diagnostics.Process.GetCurrentProcess().MainModule.FileName);
string filePath_source = Path.Combine(startPath, @"Source_Files\Offers_Source_Temp.xlsx");
string filePath_copiedinto = Path.Combine(startPath, @"Source_Files\ToBeCopiedInto.xlsx");
app = new Excel.Application();
app.DisplayAlerts = false;
book = app.Workbooks.Open(filePath_source);
sheet = (Excel.Worksheet)book.Worksheets.get_Item((1));
int iRowCount = sheet.UsedRange.Rows.Count;
int maxrows = 10;//change this to something like 50,000 later. 01/16/18
int maxloops = iRowCount / maxrows;
int beginrow = 2; //skipping the header row.
Excel.Application destxlApp;
Excel.Workbook destworkBook;
Excel.Worksheet destworkSheet;
Excel.Range destrange;
string srcPath;
string destPath;
//Opening of first worksheet and copying
srcPath = filePath_source;
for (int i = 1; i <= maxloops; i++) {
Excel.Range rng = (Excel.Range)sheet.Range[sheet.Cells[beginrow, 1], sheet.Cells[maxrows, 3]];
rng.Copy(Type.Missing);
//opening of the second worksheet and pasting
destPath = filePath_copiedinto;
destxlApp = new Excel.Application();
destxlApp.DisplayAlerts = false;
destworkBook = destxlApp.Workbooks.Open(destPath, 0, false);
destworkSheet = destworkBook.Worksheets.get_Item(1);
destrange = destworkSheet.Cells[1, 1];
destrange.Select();
destworkSheet.Paste(Type.Missing, Type.Missing);
destworkBook.SaveAs(startPath + "\\Output_Files\\" + beginrow + ".xlsx");
destworkBook.Close(true, null, null);
destxlApp.Quit();
beginrow = beginrow + maxrows;
string blah = null;
}