C#和excel删除行

时间:2012-09-03 23:46:40

标签: c# excel

我想从我的表单(在C#中)写到excel电子表格,如果空白则删除某些行。

我可以完美地写一个speadsheet并保存它,但是让我们说用户将数据输入到a1,a2,a3和a4行,我现在要删除a4和a29之间的所有行。

我需要的是找出如何删除某个范围的单元格。

由于

5 个答案:

答案 0 :(得分:6)

// Here is the answers to 
// 1. Delete entire row - Below rows will shift up
// 2. Delete few cells - Below cells will shift up
// 3. Clear few cells - No shifting

using Excel = Microsoft.Office.Interop.Excel;

Excel.Application ExcelApp = new Excel.Application();
                  Excel.Workbook ExcelWorkbook = ExcelApp.Workbooks.Open(ResultFilePath);
                  ExcelApp.Visible = true;
                  Excel.Worksheet ExcelWorksheet = ExcelWorkbook.Sheets[1];

Excel.Range TempRange = ExcelWorksheet.get_Range("H11", "J15");

// 1. To Delete Entire Row - below rows will shift up
TempRange.EntireRow.Delete(Type.Missing);

// 2. To Delete Cells - Below cells will shift up
TempRange.Cells.Delete(Type.Missing);

// 3. To clear Cells - No shifting
TempRange.Cells.Clear();

答案 1 :(得分:4)

您可以使用范围对象来完成。我假设你在使用Excel互操作。

假设你打开了你的书,然后设置范围然后将其删除 它应该看起来像这样

ApplicationClass excel = new ApplicationClass();
//Abrir libro y seleccionar la hoja adecuada aqui
//...

Microsoft.Office.Interop.Excel.Range cel = (Range)excel.Cells[rowIndex, columnIndex];
cel.Delete();

答案 2 :(得分:4)

你可以用它。 İt正在工作......

    _Application docExcel = new Microsoft.Office.Interop.Excel.Application { Visible = false };
   dynamic workbooksExcel = docExcel.Workbooks.Open(@"C:\Users\mahmut.efe\Desktop\Book4.xlsx");
   var worksheetExcel = (_Worksheet)workbooksExcel.ActiveSheet;

   ((Range)worksheetExcel.Rows[2, Missing.Value]).Delete(XlDeleteShiftDirection.xlShiftUp);

   workbooksExcel.Save();
   workbooksExcel.Close(false);
   docExcel.Application.Quit();

有关详细信息,请访问this网站

答案 3 :(得分:1)

您可以指定一个单元格(例如A1)并找到包含该单元格的整行作为范围,然后可以删除该行。

excel.Worksheet sheet =(excel.Worksheet)excelWorkBook.Sheets [“sheet1”];

excel.Range cells =(excel.Range)sheet.Range [“A1”,Type.Missing];

excel.Range del = cells.EntireRow;

<强> del.Delete();

上面给出的代码将删除sheet1的第一行

答案 4 :(得分:0)

要删除一行,您只需要遵循以下简单的代码行

xlWorkSheet.Rows[NUMBER_ROW].Delete();