Эффективный способ удаления строк из файла .xlsx с помощью С#C#

Место общения программистов C#
Ответить
Anonymous
 Эффективный способ удаления строк из файла .xlsx с помощью С#

Сообщение Anonymous »

Мне нужно удалить определенные строки из файла .xlsx с помощью программы C#.
Необходимо просмотреть всю таблицу, и если определенное слово появляется в столбце B, эту строку следует удалить.
Мое текущее решение выглядит так:

Код: Выделить всё

 public void RemoveLines(string path)
{
ExcelPackage.LicenseContext = LicenseContext.Commercial;
using (var package = new ExcelPackage(path))
{
ExcelWorksheet worksheet = package.Workbook.Worksheets[0];
for (int i = 1; i < worksheet.Rows.Count(); i++)
{
if (worksheet.Cells[i, 2].Text.ToLower().Contains("comment") || worksheet.Cells[i, 2].Text.ToLower().Contains("network"))
{
worksheet.DeleteRow(i);
i--;
}
}
package.SaveAs(path.Replace(".xlsx", "_CLEAN.xlsx"));
}
}
Это работает, но поскольку у меня огромный файл в 70 000 строк, все это занимает около 10 минут.
Я уже пробовал сохранять весь рабочий лист в массиве, но я не знаю, как вернуть исправленный массив обратно в рабочий лист^^.
Сейчас я использую пакет EPPlus.
Может ли кто-нибудь сказать мне, как я могу сделать все это еще быстрее, возможно, используя массив или другой метод?

Подробнее здесь: https://stackoverflow.com/questions/787 ... ng-c-sharp
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «C#»