[英]Excel Returns Null After Line 144 using C# Microsoft Interop Excel
In C#, I've opened an Excel spreadsheet and I am iterating through it.在 C# 中,我打开了一个 Excel 电子表格,我正在遍历它。 Whenever I get to line 144, the spreadsheet value returns null for every single line following it.每当我到达第 144 行时,电子表格值对于它后面的每一行都返回 null。 Looking at the spreadsheet, it is clearly not null for lines 144 - 250. I tried saving it in different versions but that didn't work.查看电子表格,第 144 - 250 行显然不为空。我尝试将其保存在不同的版本中,但这没有用。 I've tried copying and pasting into a brand new worksheet.我试过复制并粘贴到一个全新的工作表中。 Nothing has worked.没有任何效果。 Here is my code:这是我的代码:
// initiate Excel
Excel.Application xlApp;
Excel.Workbook xlWorkBook;
Excel.Worksheet xlWorkSheet;
object misValue = System.Reflection.Missing.Value;
xlApp = new Excel.Application();
xlWorkBook = xlApp.Workbooks.Open(lblFileName.Text, 0, true, 5, "", "", true, Microsoft.Office.Interop.Excel.XlPlatform.xlWindows, "\t", false, false, 0, true, 1, 0);
xlWorkSheet = (Excel.Worksheet)xlWorkBook.Worksheets.get_Item(1);
//Get the used Range
Excel.Range usedRange = xlWorkSheet.UsedRange;
//Iterate the rows in the used range
string customerNumber;
string amount;
int i = 0;
decimal dAmount = 0;
bool runProcess = true;
bool hasHeader = false;
string cellValue;
foreach (Excel.Range row in usedRange.Rows)
{
i++;
// Column 1 is customer number
// THE FOLLOWING LINE RETURNS NULL STARTING AT ROW 144
cellValue = row.Cells[i, 1].Value2 == null ? "" : row.Cells[i, 1].Value2.ToString();
if (!(cellValue.Length >= 5 && cellValue.Length <= 20))
{
MessageBox.Show(cellValue + " Must be between 5 and 20 Characters - File Will Not Be Processed Row#" + i.ToString());
runProcess = false;
}
}
// run process
// release EXCEL
I did try row.Cells[i, 1].Value2, row.Cells[i, 1].Value and row.Cells[i, 1].Text and got the same results for all.我确实尝试了 row.Cells[i, 1].Value2, row.Cells[i, 1].Value 和 row.Cells[i, 1].Text 并得到了相同的结果。 I am including "using Excel = Microsoft.Office.Interop.Excel;"我包括“使用 Excel = Microsoft.Office.Interop.Excel;”
Sample Data from Excel来自 Excel 的示例数据
4492605768531895 15.95
4492605768536544 19.95
4492605768565459 11.95
4492605739542347 14.95
4492605768635795 25.95
I think it has something to do with the Range object size.我认为这与 Range 对象大小有关。 I tried replace the foreach to this and it worked (for me the null was occurring in line 102)我尝试将 foreach 替换为这个并且它有效(对我来说空值发生在第 102 行)
int maxRows = usedRange.Rows.Count;
for (int i=1;i<=maxRows;i++)
{
// Column 1 is customer number
// THE FOLLOWING LINE RETURNS NULL STARTING AT ROW 144
cellValue = xlWorkSheet.Cells[i, 1].Value2 == null ? "" : xlWorkSheet.Cells[i, 1].Value2.ToString();
if (!(cellValue.Length >= 5 && cellValue.Length <= 20))
{
MessageBox.Show(cellValue + " Must be between 5 and 20 Characters - File Will Not Be Processed Row#" + i.ToString());
runProcess = false;
}
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.